/* Arcane content pages: visual system that mirrors index.html
 * Used by /security.html, /how-it-works.html, /compliance.html,
 * /compare/, /learn/**, and /404.html
 * Self-contained (~12kb). Does not depend on Webflow CSS.
 */

:root{
  --bg: #0a0b14;
  --bg-2: #0c0e1a;
  --surface: rgba(255,255,255,.04);
  --surface-strong: rgba(255,255,255,.06);
  --line: rgba(255,255,255,.08);
  --line-strong: rgba(255,255,255,.14);
  --text: #ffffff;
  --text-muted: rgba(230,232,245,.74);
  --text-faint: rgba(230,232,245,.5);
  --accent: #8a99f1;
  --accent-strong: #a3b0ff;
  --accent-glow: rgba(138,153,241,.35);
  --max: 1280px;
  --max-prose: 760px;
  --radius: 14px;
  --radius-lg: 22px;
  --radius-pill: 999px;
  --shadow-lg: 0 30px 80px -20px rgba(0,0,0,.6);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--bg)}
body{
  margin:0;
  background:
    radial-gradient(1100px 600px at 15% -10%, rgba(138,153,241,.16), transparent 60%),
    radial-gradient(900px 500px at 95% 5%, rgba(138,153,241,.10), transparent 60%),
    radial-gradient(700px 400px at 50% 110%, rgba(138,153,241,.08), transparent 60%),
    var(--bg);
  color:var(--text);
  font-family:"Work Sans","SF Pro Text",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  font-size:17px;
  line-height:1.6;
  letter-spacing:-0.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  min-height:100vh;
  overflow-x:hidden;
}
img{max-width:100%;height:auto}
a{color:#fff;text-decoration:none}
a:hover{text-decoration:none}
hr{border:0;border-top:1px solid var(--line);margin:48px 0}
.divider{border:0;border-top:1px solid var(--line);margin:64px auto;max-width:var(--max-prose)}

::selection{background:rgba(138,153,241,.4);color:#fff}

/* ---------- accessibility ---------- */
.skip-link{position:absolute;left:-9999px;top:8px;background:#0a0b14;color:#fff;padding:10px 14px;border-radius:8px;z-index:10001;border:1px solid var(--line-strong)}
.skip-link:focus{left:8px}

/* ---------- announcement bar (matches index.html) ---------- */
.announcement-bar{
  position:relative;z-index:50;width:100%;
  background:linear-gradient(90deg,rgba(138,153,241,.22),rgba(138,153,241,.08));
  border-bottom:1px solid rgba(138,153,241,.22);
  color:#e6e8f5;font-size:13px;letter-spacing:.01em;
}
.announcement-bar__inner{max-width:1280px;margin:0 auto;padding:8px 24px;display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;text-align:center;line-height:1.4}
.announcement-bar__pill{display:inline-flex;align-items:center;gap:6px;padding:2px 9px;border-radius:999px;background:rgba(138,153,241,.24);color:#e2e6ff;font-weight:600;font-size:10.5px;text-transform:uppercase;letter-spacing:.1em}
.announcement-bar__pill::before{content:"";width:6px;height:6px;border-radius:50%;background:#8a99f1;box-shadow:0 0 10px #8a99f1;animation:abPulse 2.4s ease-in-out infinite}
@keyframes abPulse{0%,100%{opacity:1}50%{opacity:.45}}
.announcement-bar a{color:#fff;font-weight:500;white-space:nowrap;border-bottom:1px solid rgba(255,255,255,.4);padding-bottom:1px;transition:border-color .15s ease}
.announcement-bar a:hover{border-color:#fff}
@media (max-width:640px){
  .announcement-bar__inner{font-size:12px;padding:7px 16px;gap:8px}
  .announcement-bar > .announcement-bar__inner > span:nth-child(2){display:none}
}

/* ---------- site header ---------- */
.site-header{
  position:sticky;top:0;z-index:40;
  background:rgba(10,11,20,.7);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.site-header__inner{
  max-width:var(--max);
  margin:0 auto;
  padding:9px 28px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.site-header__brand{display:inline-flex;align-items:center}
.site-header__brand img{height:73px;width:auto;display:block}
@media (max-width:760px){
  .site-header__brand img{height:56px}
}
.site-header__nav{display:flex;align-items:center;gap:28px}
.site-header__nav a{color:rgba(230,232,245,.78);font-size:15px;font-weight:400;letter-spacing:-.005em;transition:color .15s ease}
.site-header__nav a:hover{color:#fff}
.site-header__nav a[aria-current="page"]{color:#fff}
/* Primary CTA in nav — mirrors index.html .primary-button, including slide-up text */
.site-header__cta{
  position:relative;
  display:inline-flex !important;align-items:center;justify-content:center;gap:10px;
  padding:11px 22px;
  border-radius:100px;
  color:#151515 !important;
  background-color:#fff;
  background-image:linear-gradient(-90deg,#8a99f100 71%,#8a99f180),linear-gradient(90deg,#8a99f100 66%,#8a99f180);
  border:1px solid #fff0;
  font-weight:500;font-size:15px;letter-spacing:-.015em;
  text-transform:capitalize;
  text-decoration:none;
  overflow:hidden;
  line-height:1;
  transition:transform .25s ease,box-shadow .25s ease;
}
.site-header__cta-wrap{
  position:relative;
  display:grid;align-items:center;
  line-height:1;
  overflow:hidden;
}
.site-header__cta-wrap > span{
  grid-area:1 / 1;
  display:block;
  line-height:1;
  white-space:nowrap;
  transition:transform .4s cubic-bezier(.2,.7,.2,1);
}
.site-header__cta-wrap > span:last-child{transform:translateY(220%)}
.site-header__cta:hover .site-header__cta-wrap > span:first-child{transform:translateY(-220%)}
.site-header__cta:hover .site-header__cta-wrap > span:last-child{transform:translateY(0)}
.site-header__cta:hover{transform:translateY(-2px);box-shadow:0 18px 40px -14px rgba(138,153,241,.7)}
.site-header__cta:focus-visible{outline:2px solid #8a99f1;outline-offset:3px}
@media (prefers-reduced-motion:reduce){
  .site-header__cta-wrap > span{transition:none}
}
@media (max-width:760px){
  .site-header__inner{padding:12px 18px;gap:12px}
  .site-header__nav{gap:14px}
  .site-header__nav a:not(.site-header__cta){display:none}
}

/* ---------- breadcrumb ---------- */
.breadcrumb{max-width:var(--max);margin:18px auto 0;padding:0 28px;color:var(--text-faint);font-size:13px;letter-spacing:.02em}
.breadcrumb a{color:var(--text-faint)}
.breadcrumb a:hover{color:#fff}

/* ---------- decorative star field (mirrors hero-stars on homepage) ---------- */
.hero-stars{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:0}
.hero-stars .star{position:absolute;width:2px;height:2px;border-radius:50%;background:#fff;opacity:.5;animation:starTwinkle 3s ease-in-out infinite}
.hero-stars .star--lg{width:3px;height:3px;opacity:.7}
.hero-stars .star--sm{width:1px;height:1px;opacity:.35}
@keyframes starTwinkle{0%,100%{opacity:.2;transform:scale(.8)}50%{opacity:.9;transform:scale(1.1)}}

/* ---------- hero ---------- */
.page-hero{
  position:relative;
  max-width:var(--max);
  margin:0 auto;
  padding:96px 28px 60px;
  text-align:center;
  isolation:isolate;
}
.page-hero > *:not(.hero-stars){position:relative;z-index:1}
.page-hero .eyebrow{
  display:inline-block;
  padding:10px 14px;
  font-size:14px;font-weight:400;line-height:1;
  letter-spacing:.02em;
  -webkit-text-fill-color:transparent;
  background-image:linear-gradient(94deg,#ffffff4d,#fff 50%,#ffffff4d);
  -webkit-background-clip:text;background-clip:text;
  border:1px solid var(--line);border-radius:var(--radius-pill);
  margin-bottom:24px;
}
.page-hero h1{
  font-size:clamp(40px,7vw,84px);
  line-height:1.05;
  letter-spacing:-.03em;
  font-weight:400;
  margin:8px 0 22px;
  -webkit-text-fill-color:transparent;
  background-image:linear-gradient(180deg,#fff 0%,#cdd3fb 100%);
  -webkit-background-clip:text;background-clip:text;
}
.page-hero p.lede{
  font-size:clamp(16px,1.6vw,19px);
  line-height:1.55;
  max-width:680px;margin:0 auto;
  -webkit-text-fill-color:transparent;
  background-image:linear-gradient(314deg,#fff6,#fff 50%,#fff6);
  -webkit-background-clip:text;background-clip:text;
  letter-spacing:-.01em;
}

/* ---------- sections ---------- */
.section{
  position:relative;
  max-width:var(--max);
  margin:0 auto;
  padding:60px 28px;
}
.section--prose{
  max-width:var(--max-prose);
  padding:48px 24px;
}
.section--prose h2{
  font-size:clamp(28px,3.5vw,44px);
  line-height:1.15;
  letter-spacing:-.025em;
  font-weight:400;
  margin:48px 0 18px;
  -webkit-text-fill-color:transparent;
  background-image:linear-gradient(90deg,#fff6,#fff 50%,#fff6);
  -webkit-background-clip:text;background-clip:text;
}
.section--prose h3{font-size:20px;font-weight:500;margin:32px 0 10px;color:#fff;letter-spacing:-.01em}
.section--prose p,.section--prose ul,.section--prose ol{
  color:var(--text-muted);font-size:17px;line-height:1.65;letter-spacing:-.005em;
}
.section--prose ul,.section--prose ol{padding-left:22px}
.section--prose li{margin:8px 0}
.section--prose strong{color:#fff;font-weight:500}
.section--prose em{color:#fff;font-style:italic}
.section--prose a{color:var(--accent-strong);border-bottom:1px solid rgba(163,176,255,.3);transition:border-color .15s ease}
.section--prose a:hover{border-color:var(--accent-strong)}

/* ---------- tile grid (mirrors financial-management-cards) ---------- */
.tile-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:20px;
  margin:36px 0 0;
}
.tile{
  position:relative;
  padding:28px 24px;
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01));
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  transition:border-color .2s ease,transform .2s ease;
}
.tile::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(400px 200px at 0% 0%,rgba(138,153,241,.10),transparent 60%);
  pointer-events:none;
}
.tile:hover{border-color:var(--line-strong);transform:translateY(-2px)}
.tile h3{margin:0 0 8px;font-size:18px;font-weight:500;color:#fff;letter-spacing:-.01em}
.tile p{margin:0;color:var(--text-muted);font-size:15px;line-height:1.55}

/* ---------- callout ---------- */
.callout{
  position:relative;
  margin:36px 0;
  padding:28px 28px;
  border-radius:var(--radius-lg);
  background:linear-gradient(180deg,rgba(138,153,241,.10),rgba(138,153,241,.02));
  border:1px solid rgba(138,153,241,.22);
}
.callout h3{margin:0 0 8px;color:#fff;font-size:18px;font-weight:500;letter-spacing:-.01em}
.callout p{margin:0;color:rgba(230,232,245,.85);font-size:16px}
.callout p strong{color:#fff}

/* ---------- steps ---------- */
.steps{display:grid;gap:16px;margin:36px 0}
.step{
  display:grid;
  grid-template-columns:64px 1fr;
  gap:20px;
  padding:24px;
  border-radius:var(--radius-lg);
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01));
  border:1px solid var(--line);
}
.step .step__num{
  width:46px;height:46px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:radial-gradient(60% 60% at 30% 30%,rgba(138,153,241,.7),rgba(138,153,241,.15));
  border:1px solid rgba(138,153,241,.4);
  color:#fff;font-weight:500;font-size:18px;letter-spacing:-.01em;
  box-shadow:0 0 32px -8px var(--accent-glow);
}
.step h3{margin:0 0 6px;color:#fff;font-size:18px;font-weight:500}
.step p{margin:0;color:var(--text-muted);font-size:15px;line-height:1.6}
@media (max-width:520px){
  .step{grid-template-columns:1fr;gap:8px}
  .step .step__num{width:40px;height:40px;font-size:16px}
}

/* ---------- primary button (matches index.html .primary-button) ---------- */
.btn{
  position:relative;
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 28px;
  border-radius:var(--radius-pill);
  background:#fff;color:#151515;
  background-image:linear-gradient(-90deg,#8a99f100 71%,#8a99f180),linear-gradient(90deg,#8a99f100 66%,#8a99f180);
  border:1px solid #fff0;
  font-weight:500;font-size:16px;letter-spacing:-.015em;
  text-transform:capitalize;
  cursor:pointer;
  overflow:hidden;
  transition:transform .2s ease,box-shadow .2s ease;
  text-decoration:none;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 24px 60px -18px rgba(138,153,241,.7)}
.btn-ghost{
  background:transparent;color:#fff;
  background-image:none;
  border:1px solid var(--line-strong);
}
.btn-ghost:hover{background:rgba(255,255,255,.06);box-shadow:none}

/* Secondary text-link with arrow (mirrors .banner-link-block) */
.btn-link{
  display:inline-flex;align-items:center;gap:12px;
  color:#eee;font-size:16px;font-weight:400;letter-spacing:-.005em;
  text-decoration:none;
}
.btn-link::after{content:"→";color:#fff;font-size:16px;transition:transform .2s ease}
.btn-link:hover::after{transform:translateX(4px)}

/* ---------- CTA band ---------- */
.cta-band{
  position:relative;
  max-width:var(--max);
  margin:80px auto 0;
  padding:0 28px;
}
.cta-band__inner{
  position:relative;
  padding:56px 48px;
  border-radius:var(--radius-lg);
  background:
    radial-gradient(600px 240px at 100% 0%,rgba(138,153,241,.25),transparent 60%),
    linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));
  border:1px solid var(--line-strong);
  display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;
  overflow:hidden;
}
.cta-band__inner::after{
  content:"";position:absolute;top:0;right:0;width:240px;height:240px;
  background:radial-gradient(circle,rgba(138,153,241,.3),transparent 70%);
  filter:blur(40px);pointer-events:none;
}
.cta-band__copy{max-width:600px;position:relative;z-index:1}
.cta-band h2{
  margin:0 0 8px;
  font-size:clamp(26px,3vw,40px);
  line-height:1.1;letter-spacing:-.025em;font-weight:400;
  -webkit-text-fill-color:transparent;
  background-image:linear-gradient(90deg,#fff,#cdd3fb);
  -webkit-background-clip:text;background-clip:text;
}
.cta-band p{margin:0;color:var(--text-muted);font-size:17px}
.cta-band .btn,.cta-band .btn-ghost{position:relative;z-index:1}
@media (max-width:680px){
  .cta-band__inner{padding:36px 24px;flex-direction:column;align-items:flex-start}
}

/* ---------- footer ---------- */
.site-footer{
  margin-top:96px;
  border-top:1px solid var(--line);
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.3));
}
.site-footer__inner{
  max-width:var(--max);
  margin:0 auto;
  padding:32px 28px;
  display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
  color:var(--text-faint);font-size:14px;
}
.site-footer nav{display:flex;flex-wrap:wrap;gap:18px}
.site-footer nav a{color:var(--text-faint);font-size:14px}
.site-footer nav a:hover{color:#fff}

/* ---------- blog list ---------- */
.tag{display:inline-block;padding:3px 10px;border-radius:999px;background:rgba(138,153,241,.14);color:#cdd3fb;font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;font-weight:500}
.post-list{display:grid;gap:16px;margin:36px 0;grid-template-columns:1fr}
@media (min-width:680px){.post-list{grid-template-columns:1fr 1fr}}
.post-card{
  display:block;
  padding:28px 24px;
  border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01));
  border-radius:var(--radius-lg);
  text-decoration:none;
  transition:border-color .2s ease,transform .2s ease;
  position:relative;overflow:hidden;
}
.post-card:hover{border-color:var(--line-strong);transform:translateY(-2px)}
.post-card h3{margin:10px 0 6px;font-size:21px;color:#fff;font-weight:500;letter-spacing:-.01em}
.post-card p{margin:0;color:var(--text-muted);font-size:15px;line-height:1.55}
.post-card__meta{font-size:11.5px;color:var(--accent-strong);letter-spacing:.08em;text-transform:uppercase;font-weight:500}

/* ---------- article (long-form) ---------- */
.article{max-width:var(--max-prose);margin:0 auto;padding:0 24px}
.article p,.article ul,.article ol{font-size:18px;color:var(--text-muted);line-height:1.7;letter-spacing:-.005em}
.article h2{
  margin:56px 0 18px;
  font-size:clamp(26px,3vw,38px);font-weight:400;
  line-height:1.15;letter-spacing:-.02em;
  -webkit-text-fill-color:transparent;
  background-image:linear-gradient(90deg,#fff6,#fff 50%,#fff6);
  -webkit-background-clip:text;background-clip:text;
}
.article blockquote{
  position:relative;
  margin:32px 0;
  padding:20px 28px;
  border-left:3px solid var(--accent);
  background:linear-gradient(90deg,rgba(138,153,241,.06),transparent 80%);
  color:#fff;font-style:italic;font-size:19px;line-height:1.55;
}
.article strong{color:#fff;font-weight:500}
.article a{color:var(--accent-strong);border-bottom:1px solid rgba(163,176,255,.3);transition:border-color .15s ease}
.article a:hover{border-color:var(--accent-strong)}

.byline{display:flex;align-items:center;justify-content:center;gap:10px;color:var(--text-faint);font-size:13px;margin-top:18px;letter-spacing:.02em}
.byline time{color:var(--text-faint)}

/* ---------- related reading ---------- */
.related-posts{max-width:var(--max-prose);margin:64px auto 0;padding:32px 24px 0;border-top:1px solid var(--line)}
.related-posts h2{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-faint);margin:0 0 18px;font-weight:500;background:none;-webkit-text-fill-color:initial}
.related-posts ul{list-style:none;padding:0;margin:0;display:grid;gap:14px}
.related-posts a{
  color:#fff;font-size:17px;letter-spacing:-.01em;
  display:inline-flex;align-items:center;gap:10px;
  transition:color .15s ease;
}
.related-posts a:hover{color:var(--accent-strong)}
.related-posts a::after{content:"→";color:var(--text-faint);transition:transform .2s ease,color .2s ease}
.related-posts a:hover::after{transform:translateX(4px);color:var(--accent-strong)}

/* ---------- anonymity set growth (how-it-works) ---------- */
.anonymity-figure{margin:36px 0 8px;padding:0}
.anonymity-set{
  position:relative;
  width:100%;max-width:640px;
  margin:0 auto;
  padding:48px 32px 64px;
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01));
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  isolation:isolate;
  min-height:280px;
}
.anonymity-set::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(60% 50% at 50% 50%,rgba(138,153,241,.08),transparent 60%);
  pointer-events:none;z-index:0;
}

.as-states{position:relative;z-index:1}
.as-state{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:flex-start;
  padding:48px 32px 64px;
  opacity:0;
  animation:asReveal 18s ease-in-out infinite;
}
.as-state:nth-child(1){animation-delay:0s}
.as-state:nth-child(2){animation-delay:3.6s}
.as-state:nth-child(3){animation-delay:7.2s}
.as-state:nth-child(4){animation-delay:10.8s}
.as-state:nth-child(5){animation-delay:14.4s}

@keyframes asReveal{
  0%,2%{opacity:0}
  4%,18%{opacity:1}
  22%,100%{opacity:0}
}

.as-counter{
  font-size:clamp(48px,8vw,84px);
  line-height:1;letter-spacing:-.04em;font-weight:400;
  -webkit-text-fill-color:transparent;
  background-image:linear-gradient(180deg,#fff,#cdd3fb);
  -webkit-background-clip:text;background-clip:text;
  margin:0;
}
.as-caption{
  font-size:13px;letter-spacing:.04em;
  color:var(--text-faint);
  margin:6px 0 28px;text-transform:lowercase;
}
.as-pool{
  position:relative;
  width:100%;max-width:480px;height:120px;
  border-radius:14px;
  border:1px solid rgba(138,153,241,.18);
  background:
    radial-gradient(60% 50% at 50% 0%,rgba(255,255,255,.06),transparent 60%),
    linear-gradient(180deg,rgba(255,255,255,.02),rgba(0,0,0,.18));
  overflow:hidden;
}
.as-pool::after{
  content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(circle,rgba(138,153,241,.85) 1px,transparent 1.5px),
    radial-gradient(circle,rgba(205,211,251,.7) 1px,transparent 1.5px);
  background-position:0 0,4px 4px;
}
/* density per state, smaller background-size = denser */
.as-state--1 .as-pool::after{background-size:120px 120px,140px 140px;opacity:.0}
.as-state--1 .as-pool .as-single{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:14px;height:14px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff,#8a99f1);box-shadow:0 0 18px rgba(138,153,241,.7)}
.as-state--2 .as-pool::after{background-size:48px 48px,56px 56px;opacity:.85}
.as-state--3 .as-pool::after{background-size:22px 22px,26px 26px;opacity:.9}
.as-state--4 .as-pool::after{background-size:12px 12px,14px 14px;opacity:.95}
.as-state--5 .as-pool::after{background-size:7px 7px,9px 9px;opacity:1}

.as-verdict{
  margin-top:24px;
  font-size:13px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--text-faint);font-weight:500;
}
.as-verdict__pill{
  display:inline-block;padding:4px 10px;border-radius:999px;
  margin-left:6px;letter-spacing:.06em;text-transform:none;font-weight:500;
}
.as-verdict__pill--low{background:rgba(255,140,140,.16);color:#ffb3b3;border:1px solid rgba(255,140,140,.3)}
.as-verdict__pill--ok{background:rgba(255,200,120,.14);color:#ffd09a;border:1px solid rgba(255,200,120,.3)}
.as-verdict__pill--good{background:rgba(138,153,241,.18);color:#cdd3fb;border:1px solid rgba(138,153,241,.4)}
.as-verdict__pill--strong{background:rgba(120,220,170,.16);color:#a8e6c8;border:1px solid rgba(120,220,170,.3)}

@media (max-width:680px){
  .anonymity-set{padding:36px 20px 48px;min-height:240px}
  .as-state{padding:36px 20px 48px}
  .as-pool{height:96px}
}
@media (prefers-reduced-motion:reduce){
  .as-state{position:relative;opacity:1;animation:none;margin-bottom:24px}
  .as-state:not(:last-child){border-bottom:1px solid var(--line);padding-bottom:36px}
}

/* ---------- wallet graph reveal (blog explainer) ---------- */
.wallet-graph-figure{margin:36px 0 8px;padding:0}
.wallet-graph{
  position:relative;
  width:100%;max-width:640px;
  aspect-ratio:16/10;
  margin:0 auto;
  padding:24px;
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01));
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  isolation:isolate;
}
.wallet-graph::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(50% 50% at 50% 50%,rgba(138,153,241,.10),transparent 60%);
  pointer-events:none;z-index:0;
}
.wallet-graph__svg{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none}
.wallet-graph__svg path{
  fill:none;
  stroke:rgba(138,153,241,.55);
  stroke-width:1.5;
  stroke-linecap:round;
  stroke-dasharray:100;
  stroke-dashoffset:100;
  animation:wgDraw 12s ease-in-out infinite;
}
@keyframes wgDraw{
  0%,4%{stroke-dashoffset:100;opacity:0}
  8%{opacity:.85}
  18%{stroke-dashoffset:0;opacity:1}
  78%{stroke-dashoffset:0;opacity:1}
  92%,100%{stroke-dashoffset:0;opacity:0}
}

.wg-node{
  position:absolute;z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  transform:translate(-50%,-50%);
  opacity:0;
  animation:wgFade 12s ease-in-out infinite;
}
.wg-node__dot{
  width:30px;height:30px;border-radius:50%;
  background:radial-gradient(60% 60% at 30% 30%,rgba(138,153,241,.7),rgba(138,153,241,.18));
  border:1px solid rgba(138,153,241,.4);
  box-shadow:0 0 20px -4px var(--accent-glow);
}
.wg-node__label{
  font-size:11px;color:#fff;font-weight:500;
  letter-spacing:-.005em;
  white-space:nowrap;
  text-shadow:0 1px 2px rgba(0,0,0,.6);
}
.wg-node--you{transform:translate(-50%,-50%) scale(1.15)}
.wg-node--you .wg-node__dot{
  width:46px;height:46px;
  background:radial-gradient(60% 60% at 30% 30%,#fff,#8a99f1);
  border:1.5px solid rgba(255,255,255,.6);
  box-shadow:0 0 36px -4px rgba(138,153,241,.9);
  animation:wgPulse 2.6s ease-in-out infinite;
}
.wg-node--you .wg-node__label{font-size:12px;color:#fff;font-weight:600;letter-spacing:.01em}
@keyframes wgPulse{0%,100%{box-shadow:0 0 36px -4px rgba(138,153,241,.9)}50%{box-shadow:0 0 56px 2px rgba(138,153,241,1)}}

@keyframes wgFade{
  0%,6%{opacity:0}
  14%,78%{opacity:1}
  92%,100%{opacity:0}
}
.wg-node--you{animation:none;opacity:1}

/* Staggered reveal: each connection + node fades in slightly later */
.wallet-graph__svg path:nth-of-type(1),.wg-node:nth-of-type(2){animation-delay:.4s}
.wallet-graph__svg path:nth-of-type(2),.wg-node:nth-of-type(3){animation-delay:.8s}
.wallet-graph__svg path:nth-of-type(3),.wg-node:nth-of-type(4){animation-delay:1.2s}
.wallet-graph__svg path:nth-of-type(4),.wg-node:nth-of-type(5){animation-delay:1.6s}
.wallet-graph__svg path:nth-of-type(5),.wg-node:nth-of-type(6){animation-delay:2.0s}
.wallet-graph__svg path:nth-of-type(6),.wg-node:nth-of-type(7){animation-delay:2.4s}
.wallet-graph__svg path:nth-of-type(7),.wg-node:nth-of-type(8){animation-delay:2.8s}
.wallet-graph__svg path:nth-of-type(8),.wg-node:nth-of-type(9){animation-delay:3.2s}
.wallet-graph__svg path:nth-of-type(9),.wg-node:nth-of-type(10){animation-delay:3.6s}

.wallet-graph__caption{
  position:absolute;left:50%;bottom:14px;transform:translate(-50%,0);
  font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--text-faint);font-weight:500;z-index:3;
}

@media (max-width:680px){
  .wallet-graph{aspect-ratio:1/1.05;max-width:360px}
  .wg-node__label{font-size:10px}
}
@media (prefers-reduced-motion:reduce){
  .wallet-graph__svg path{stroke-dashoffset:0;animation:none;opacity:.7}
  .wg-node{opacity:1;animation:none}
}

/* ---------- privacy demo (gumball machine) ---------- */
.gumball-figure{margin:36px 0 8px;padding:0}
.gumball-machine{
  position:relative;
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:40px 28px;
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01));
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  isolation:isolate;
}
.gumball-machine::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(60% 50% at 50% 50%,rgba(138,153,241,.08),transparent 60%);
  pointer-events:none;z-index:0;
}

.gm-wallet{
  position:relative;z-index:2;flex:0 0 auto;
  display:flex;flex-direction:column;align-items:center;gap:8px;min-width:84px;
}
.gm-wallet__icon{
  width:52px;height:52px;border-radius:14px;
  background:radial-gradient(60% 60% at 30% 30%,rgba(138,153,241,.7),rgba(138,153,241,.18));
  border:1px solid rgba(138,153,241,.4);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;font-weight:500;color:#fff;letter-spacing:-.02em;
  box-shadow:0 0 32px -8px var(--accent-glow);
}
.gm-wallet__label{font-size:13px;color:#fff;font-weight:500;letter-spacing:-.005em}
.gm-wallet__addr{font-size:11.5px;color:var(--text-faint);font-family:"SF Mono","JetBrains Mono",ui-monospace,Menlo,monospace}

.gm-pipe{
  position:relative;flex:1 1 60px;height:2px;
  min-width:32px;max-width:120px;
  background-image:linear-gradient(90deg,rgba(138,153,241,.45) 0 8px,transparent 8px 16px);
  background-size:16px 2px;
  z-index:1;
}
.gm-dot{
  position:absolute;top:50%;left:0;
  width:10px;height:10px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,#fff,#8a99f1);
  box-shadow:0 0 16px rgba(138,153,241,.8);
  transform:translateY(-50%);
  opacity:0;
}
.gm-pipe--in .gm-dot{animation:gmTravelH 7s ease-in-out infinite}
.gm-pipe--out .gm-dot{animation:gmTravelH 7s ease-in-out infinite;animation-delay:3.5s}
@keyframes gmTravelH{
  0%,5%{left:0;opacity:0}
  10%{opacity:1}
  40%{left:calc(100% - 10px);opacity:1}
  45%,100%{opacity:0}
}

.gm-pool{
  flex:1 1 380px;position:relative;
  height:240px;max-width:440px;
  border-radius:28px;
  background:
    radial-gradient(80% 50% at 50% 0%,rgba(255,255,255,.14),transparent 60%),
    radial-gradient(70% 70% at 70% 80%,rgba(138,153,241,.18),transparent 60%),
    linear-gradient(180deg,rgba(255,255,255,.04),rgba(0,0,0,.18));
  border:1px solid rgba(138,153,241,.22);
  overflow:hidden;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.12),
    inset 0 0 60px -10px rgba(0,0,0,.5),
    0 0 80px -30px var(--accent-glow);
  z-index:1;
}
.gm-pool__label{
  position:absolute;bottom:10px;left:50%;transform:translateX(-50%);
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--text-faint);font-weight:500;white-space:nowrap;z-index:3;
}

.gm-ball{position:absolute;border-radius:50%;animation:gmFloat 5s ease-in-out infinite}
.gm-ball--1{background:radial-gradient(circle at 30% 30%,#fff,#c7d0ff);box-shadow:0 0 8px rgba(199,208,255,.4)}
.gm-ball--2{background:radial-gradient(circle at 30% 30%,#cdd3fb,#8a99f1);box-shadow:0 0 8px rgba(138,153,241,.4)}
.gm-ball--3{background:radial-gradient(circle at 30% 30%,#e7e9f7,#9aa6e8);box-shadow:0 0 8px rgba(154,166,232,.3)}
.gm-ball--4{background:radial-gradient(circle at 30% 30%,#bcc8ff,#6b7ad6);box-shadow:0 0 8px rgba(107,122,214,.3)}
.gm-ball--5{background:radial-gradient(circle at 30% 30%,#fff,#a3b0ff);box-shadow:0 0 8px rgba(163,176,255,.3)}
@keyframes gmFloat{
  0%,100%{transform:translate(0,0)}
  25%{transform:translate(3px,-2px)}
  50%{transform:translate(-2px,3px)}
  75%{transform:translate(2px,2px)}
}

.gumball-caption{
  font-size:14px;color:var(--text-faint);
  text-align:center;margin:14px auto 0;
  font-style:italic;line-height:1.55;max-width:560px;
}

@media (max-width:680px){
  .gumball-machine{flex-direction:column;padding:32px 20px;gap:18px}
  .gm-pool{flex:0 0 auto;width:100%;max-width:none;height:200px}
  .gm-pipe{
    width:2px;height:42px;min-width:0;max-width:none;flex:0 0 auto;
    background-image:linear-gradient(0deg,rgba(138,153,241,.45) 0 8px,transparent 8px 16px);
    background-size:2px 16px;
  }
  .gm-dot{transform:translateX(-50%);top:0;left:50%}
  .gm-pipe--in .gm-dot{animation-name:gmTravelV}
  .gm-pipe--out .gm-dot{animation-name:gmTravelV;animation-delay:3.5s}
  @keyframes gmTravelV{
    0%,5%{top:0;opacity:0}
    10%{opacity:1}
    40%{top:calc(100% - 10px);opacity:1}
    45%,100%{opacity:0}
  }
}

@media (prefers-reduced-motion:reduce){
  .gm-ball,.gm-pipe--in .gm-dot,.gm-pipe--out .gm-dot{animation:none}
}

/* ---------- motion ---------- */
@media (prefers-reduced-motion:no-preference){
  .page-hero .eyebrow{animation:fadeUp .55s ease-out both}
  .page-hero h1{animation:fadeUp .65s .05s ease-out both}
  .page-hero p.lede{animation:fadeUp .7s .1s ease-out both}
}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---------- not-found page hooks (for 404.html) ---------- */
.not-found{position:relative;min-height:60vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:96px 24px 60px;max-width:760px;margin:0 auto;isolation:isolate}
.not-found > *:not(.hero-stars){position:relative;z-index:1}
.not-found__eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-strong);font-weight:500}
.not-found h1{
  font-size:clamp(48px,8vw,96px);line-height:1;margin:20px 0 18px;
  letter-spacing:-.035em;font-weight:400;
  -webkit-text-fill-color:transparent;
  background-image:linear-gradient(180deg,#fff,#cdd3fb);
  -webkit-background-clip:text;background-clip:text;
}
.not-found p{font-size:17px;color:var(--text-muted);max-width:560px;margin:0 0 32px}
.not-found__cta{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.not-found__suggestions{max-width:680px;margin:64px auto 0;padding:32px 24px 0;border-top:1px solid var(--line);width:100%}
.not-found__suggestions h2{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);font-weight:500;margin:0 0 18px;background:none;-webkit-text-fill-color:initial}
.not-found__suggestions ul{list-style:none;padding:0;margin:0;display:grid;gap:12px;text-align:left}
.not-found__suggestions a{color:#fff;font-size:17px;display:inline-flex;align-items:center;gap:10px;transition:color .15s ease}
.not-found__suggestions a:hover{color:var(--accent-strong)}
.not-found__suggestions a::after{content:"→";color:var(--text-faint);transition:transform .2s ease,color .2s ease}
.not-found__suggestions a:hover::after{transform:translateX(4px);color:var(--accent-strong)}
