/* ============================================================
   JUWEL · Liquid landing — juwel-liquid.css
   Builds on juwel-ds.css tokens. Motion vocabulary:
   sheet-pull · gooey press · melt-open · fluid expand ·
   crystallize · rebound. Motion scaled by --mx (tweak).
   ============================================================ */

:root{
  --mx:1;                       /* motion intensity multiplier (0.2 – 1.5) */
  --bounce:cubic-bezier(.34,1.56,.64,1);
  --nav-h:72px;
}
html,body{overscroll-behavior-y:none;}
body{overflow-x:clip;}
#spacer{display:none;}
body.mode-flow #spacer{display:block;width:1px;}
body.mode-flow #scroller{position:fixed;top:0;left:0;right:0;will-change:transform;}

/* ── nav ── */
.nav{position:fixed;top:0;left:0;right:0;z-index:80;height:var(--nav-h);
  display:flex;align-items:center;gap:10px;padding:0 clamp(18px,3.5vw,44px);
  transition:background .35s var(--ease),box-shadow .35s var(--ease);}
.nav.scrolled{background:color-mix(in srgb,var(--paper) 72%,transparent);
  backdrop-filter:blur(18px) saturate(1.5);box-shadow:0 1px 0 var(--line-2);}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink);}
.brand img{width:34px;height:34px;transition:transform .5s var(--bounce);}
.brand:hover img{transform:rotate(-14deg) scale(1.12);}
.brand .wm{font-weight:900;font-size:21px;letter-spacing:-.03em;
  background:linear-gradient(90deg,var(--topaz-2),var(--garnet-2) 55%,var(--amethyst-2));
  -webkit-background-clip:text;background-clip:text;color:transparent;}
.nav-r{margin-left:auto;display:flex;align-items:center;gap:8px;}
.nlink{font-size:14.5px;font-weight:600;color:var(--ink-2);text-decoration:none;padding:10px 14px;border-radius:var(--r-full);
  transition:color .18s,background .18s,transform .3s var(--bounce);}
.nlink:hover{color:var(--ink);background:color-mix(in srgb,var(--surface) 80%,transparent);transform:translateY(-2px);}
@media(max-width:840px){.nlink{display:none;}}
.icon-btn{width:44px;height:44px;display:grid;place-items:center;border:1.5px solid var(--line);background:color-mix(in srgb,var(--surface) 65%,transparent);
  color:var(--ink-2);border-radius:var(--r-full);cursor:pointer;backdrop-filter:blur(8px);
  transition:transform .35s var(--bounce),color .18s,background .18s;}
.icon-btn:hover{color:var(--ink);transform:translateY(-2px) scale(1.06);}
.icon-btn:active{transform:scale(.92);}
.icon-btn svg{width:19px;height:19px;}
#themeBtn .moon{display:none;}
html[data-theme="dark"] #themeBtn .sun{display:none;}
html[data-theme="dark"] #themeBtn .moon{display:block;}

/* melt-open menu */
.menu-wrap{position:relative;}
.menu-pop{position:absolute;top:calc(100% + 12px);right:0;min-width:236px;z-index:90;
  background:var(--surface);border-radius:var(--r-lg);padding:10px;
  box-shadow:var(--shadow-lg),inset 0 0 0 1.5px var(--line-2);
  transform-origin:top right;display:none;}
.menu-pop.open{display:block;animation:meltOpen calc(.55s*var(--mx)) var(--bounce) both;}
.menu-pop.closing{display:block;animation:meltClose calc(.3s*var(--mx)) var(--ease) both;}
@keyframes meltOpen{
  0%{transform:scaleY(.32) scaleX(.86);border-radius:40px;opacity:0;}
  55%{transform:scaleY(1.07) scaleX(1.01);opacity:1;}
  78%{transform:scaleY(.97) scaleX(1);}
  100%{transform:scale(1);border-radius:var(--r-lg);opacity:1;}}
@keyframes meltClose{to{transform:scaleY(.4) scaleX(.9);opacity:0;}}
.menu-pop::after{content:"";position:absolute;left:50%;bottom:-7px;width:14px;height:14px;border-radius:50%;
  background:var(--surface);box-shadow:inset 0 0 0 1.5px var(--line-2);
  transform:translateX(-50%) scale(0);}
.menu-pop.open::after{animation:drip calc(.7s*var(--mx)) var(--bounce) .12s both;}
@keyframes drip{0%{transform:translateX(-50%) scale(0);}60%{transform:translateX(-50%) translateY(4px) scale(1);}100%{transform:translateX(-50%) scale(.85);}}
.menu-pop a{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--r-sm);
  text-decoration:none;color:var(--ink);font-weight:700;font-size:15px;
  transition:background .15s,transform .3s var(--bounce);opacity:0;transform:translateY(-8px);}
.menu-pop.open a{animation:itemIn calc(.5s*var(--mx)) var(--bounce) both;animation-delay:calc(var(--i)*60ms*var(--mx) + 80ms);}
@keyframes itemIn{to{opacity:1;transform:none;}}
.menu-pop a:hover{background:var(--surface-2);transform:translateX(4px);}
.menu-pop a .mi{width:32px;height:32px;border-radius:10px;display:grid;place-items:center;color:#fff;flex:none;
  background:linear-gradient(160deg,var(--g,var(--topaz)),var(--gd,var(--topaz-deep)));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.45);}
.menu-pop a .mi svg{width:16px;height:16px;}
.menu-pop a small{display:block;font-weight:500;font-size:12px;color:var(--ink-3);margin-top:1px;}

/* ── scenes ── */
.scene{position:relative;}
.pinwrap{position:relative;}
.pin{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:center;
  padding:calc(var(--nav-h) + 24px) clamp(20px,4.5vw,56px) 48px;}
body.mode-story .pinwrap{height:230vh;}
body.mode-story .pinwrap .pin{position:sticky;top:0;height:100vh;min-height:0;overflow:clip;}
.inner{width:min(1160px,100%);margin:0 auto;}

/* hero */
#s-hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  padding:calc(var(--nav-h) + 20px) 24px 90px;position:relative;}
body.mode-story #s-hero-wrap{height:170vh;}
body.mode-story #s-hero{position:sticky;top:0;height:100vh;min-height:0;overflow:clip;}
.hero-stack{display:flex;flex-direction:column;align-items:center;will-change:transform,opacity;}
#s-hero .eyebrow.pill{margin-bottom:26px;}
#s-hero h1{margin:26px 0 0;max-width:12ch;}
#s-hero .t-lede{margin:22px auto 0;max-width:44ch;}
.hero-cta{margin-top:34px;display:flex;gap:14px;align-items:center;justify-content:center;flex-wrap:wrap;}
.verify-line{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:13px;color:var(--ink-2);
  background:color-mix(in srgb,var(--surface) 70%,transparent);border:1.5px solid var(--line);border-radius:var(--r-full);
  padding:12px 18px;cursor:copy;transition:border-color .2s,transform .3s var(--bounce);}
.verify-line:hover{border-color:color-mix(in srgb,var(--accent-deep) 45%,transparent);transform:translateY(-2px);}
.verify-line .dot{width:7px;height:7px;border-radius:50%;background:var(--jade-deep);box-shadow:0 0 0 3px color-mix(in srgb,var(--jade-2) 30%,transparent);}
.scrollcue{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:7px;cursor:pointer;
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);transition:opacity .4s;}
.scrollcue i{width:22px;height:34px;border:1.5px solid var(--line);border-radius:12px;position:relative;}
.scrollcue i::after{content:"";position:absolute;left:50%;top:6px;width:4px;height:8px;border-radius:3px;background:var(--accent-deep);
  transform:translateX(-50%);animation:cueDrop 1.7s var(--ease) infinite;}
@keyframes cueDrop{0%{top:6px;opacity:1;}70%{top:18px;opacity:0;}100%{top:6px;opacity:0;}}

/* section headers */
.kick{display:flex;justify-content:center;margin-bottom:14px;}
.scene h2{margin:0 auto;text-align:center;max-width:16ch;text-wrap:balance;}
.scene .sub{margin:18px auto 0;max-width:52ch;text-align:center;font-size:clamp(16px,1.8vw,20px);font-weight:500;color:var(--ink-2);line-height:1.5;text-wrap:pretty;}
.scene .sub b{color:var(--ink);font-weight:700;}

/* scene 2 — she acts */
.actbar{margin:44px auto 0;max-width:640px;}
.inputbar{display:flex;align-items:center;gap:12px;background:var(--surface);border-radius:var(--r-full);padding:11px 13px 11px 26px;
  box-shadow:var(--shadow),inset 0 0 0 1.5px var(--line-2);}
.inputbar .ph{color:var(--ink);font-size:clamp(15px,1.8vw,17px);font-weight:600;flex:1;text-align:left;min-height:1.4em;white-space:nowrap;overflow:hidden;}
.inputbar .caret{display:inline-block;width:2px;height:1.1em;background:var(--accent-deep);vertical-align:text-bottom;margin-left:1px;
  animation:caret 1s steps(2) infinite;}
@keyframes caret{50%{opacity:0;}}
.inputbar .go{width:48px;height:48px;border-radius:50%;flex:none;background:linear-gradient(180deg,var(--accent-2),var(--accent-deep));
  display:grid;place-items:center;color:#fff;box-shadow:inset 0 1px 0 rgba(255,255,255,.6),var(--glow-amber);border:none;cursor:pointer;
  transition:transform .35s var(--bounce);}
.inputbar .go:hover{transform:scale(1.1);}
.inputbar .go:active{transform:scale(.9);}
.inputbar .go svg{width:19px;height:19px;}
.sticker-field{margin:40px auto 0;display:flex;gap:16px;flex-wrap:wrap;justify-content:center;max-width:880px;}
.sticker{--pop:0;opacity:var(--pop);transform:translateY(calc((1 - var(--pop))*46px)) scale(calc(.6 + .4*var(--pop))) rotate(var(--rot,0deg));
  transition:none;}
body.mode-flow .sticker,body.mode-static .sticker{transition:opacity calc(.6s*var(--mx)) var(--ease),transform calc(.7s*var(--mx)) var(--bounce);transition-delay:var(--d,0s);}
.sticker .action{cursor:pointer;transition:transform .35s var(--bounce),box-shadow .35s;}
.sticker .action:hover{transform:translateY(-6px) rotate(-1.2deg) scale(1.04);box-shadow:var(--shadow-lg);}

/* scene 3 — she remembers */
.mem-field{position:relative;margin:52px auto 0;max-width:960px;display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
@media(max-width:840px){.mem-field{grid-template-columns:repeat(2,1fr);}}
.mem{--p:0;cursor:pointer;background:var(--surface);border-radius:var(--r-md);padding:16px;box-shadow:var(--shadow),inset 0 0 0 1.5px var(--line-2);
  display:flex;flex-direction:column;gap:9px;text-align:left;
  transform:translate(calc(var(--sx)*(1 - var(--p))),calc(var(--sy)*(1 - var(--p)))) rotate(calc(var(--sr)*(1 - var(--p)))) scale(calc(.82 + .18*var(--p)));
  opacity:calc(.25 + .75*var(--p));}
body.mode-flow .mem,body.mode-static .mem{transition:transform calc(.9s*var(--mx)) var(--bounce),opacity calc(.6s*var(--mx)) var(--ease);transition-delay:var(--d,0s);}
.mem .mi{width:34px;height:34px;border-radius:11px;display:grid;place-items:center;color:#fff;
  background:linear-gradient(160deg,var(--g,var(--topaz)),var(--gd,var(--topaz-deep)));box-shadow:inset 0 1px 0 rgba(255,255,255,.45);}
.mem .mi svg{width:17px;height:17px;}
.mem b{font-size:14.5px;letter-spacing:-.01em;font-weight:800;}
.mem span{font-family:var(--mono);font-size:11px;color:var(--ink-3);}

/* scene 4 — receipt */
.receipt-stage{margin:48px auto 0;display:flex;justify-content:center;perspective:900px;}
.receipt{--unf:0;width:min(520px,92vw);transform-origin:top center;position:relative;
  transform:rotateX(calc((1 - var(--unf))*-68deg)) translateY(calc((1 - var(--unf))*-26px));
  opacity:calc(.15 + .85*var(--unf));}
body.mode-flow .receipt,body.mode-static .receipt{transition:transform calc(1s*var(--mx)) var(--bounce),opacity calc(.5s*var(--mx)) var(--ease);}
.receipt .row,.receipt .sig{--rp:0;opacity:var(--rp);transform:translateY(calc((1 - var(--rp))*10px));}
body.mode-flow .receipt .row,body.mode-flow .receipt .sig,
body.mode-static .receipt .row,body.mode-static .receipt .sig{transition:opacity calc(.5s*var(--mx)) var(--ease),transform calc(.5s*var(--mx)) var(--bounce);transition-delay:var(--d,0s);}
.receipt .rh .v.bad{color:var(--garnet-2);}
.receipt .rh .v.bad i{background:var(--garnet-2);box-shadow:0 0 10px var(--garnet-2);}
.receipt.tampered{animation:wobble calc(.55s*var(--mx)) var(--ease);box-shadow:var(--shadow-lg),0 0 0 2px var(--garnet-deep),0 24px 70px -24px rgba(226,58,96,.55);}
.receipt.tampered .sig{color:var(--garnet);}
.receipt .sig em{font-style:normal;color:var(--garnet);background:rgba(226,58,96,.22);border-radius:4px;padding:0 2px;}
@keyframes wobble{0%,100%{transform:rotate(0) rotateX(0);}20%{transform:rotate(-1.6deg);}45%{transform:rotate(1.3deg);}70%{transform:rotate(-.7deg);}}
.receipt.verified-pop{animation:crystal calc(.6s*var(--mx)) var(--bounce);}
@keyframes crystal{0%{transform:scale(.97);}55%{transform:scale(1.025);}100%{transform:scale(1);}}
.tamper-row{margin:26px auto 0;display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}
.moat{margin:30px auto 0;max-width:56ch;text-align:center;font-size:clamp(16px,1.9vw,21px);font-weight:600;color:var(--ink-2);line-height:1.5;}
.moat b{color:var(--ink);}
.moat .serif{color:var(--amethyst-2);font-size:1.08em;}

/* scene 5 — professions (17 cuts, centered wrap) */
.gem-grid{margin:46px auto 0;display:flex;flex-wrap:wrap;justify-content:center;gap:14px;max-width:1160px;}
.gemcard{position:relative;border:none;text-align:left;font-family:inherit;border-radius:var(--r-xl);padding:18px 16px;color:#fff;overflow:hidden;
  width:204px;min-height:150px;display:flex;flex-direction:column;justify-content:flex-end;gap:2px;cursor:pointer;
  background:linear-gradient(160deg,var(--g),var(--gd));
  box-shadow:var(--shadow),inset 0 1.5px 0 rgba(255,255,255,.4);
  transition:transform .45s var(--bounce),box-shadow .45s var(--ease);}
.gemcard.ink-dark{color:#241A38;}
@media(max-width:560px){.gemcard{width:calc(50% - 7px);min-height:132px;}}
.gemcard::before{content:"";position:absolute;left:0;right:0;top:0;height:46%;background:linear-gradient(180deg,rgba(255,255,255,.42),transparent);pointer-events:none;}
.gemcard:hover{transform:translateY(-8px) scale(1.03) rotate(-.6deg);box-shadow:var(--shadow-lg),inset 0 1.5px 0 rgba(255,255,255,.4);}
.gemcard:active{transform:scale(.97);}
.gemcard .g-k{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;opacity:.92;}
.gemcard .g-t{font-weight:900;font-size:19px;letter-spacing:-.02em;}
.gemcard .g-open{position:absolute;top:16px;right:16px;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;
  background:rgba(255,255,255,.26);backdrop-filter:blur(6px);box-shadow:inset 0 1px 0 rgba(255,255,255,.5);
  transition:transform .4s var(--bounce);}
.gemcard:hover .g-open{transform:rotate(90deg) scale(1.1);}
.gemcard .g-open svg{width:16px;height:16px;}

/* fluid-expand detail overlay */
#detailScrim{position:fixed;inset:0;z-index:95;background:color-mix(in srgb,var(--ink) 32%,transparent);
  backdrop-filter:blur(14px) saturate(1.3);opacity:0;pointer-events:none;transition:opacity calc(.4s*var(--mx)) var(--ease);}
#detailScrim.on{opacity:1;pointer-events:auto;}
#detail{position:fixed;z-index:96;top:0;left:0;color:#fff;border-radius:var(--r-xl);overflow:hidden;display:none;
  background:linear-gradient(160deg,var(--g,var(--topaz)),var(--gd,var(--topaz-deep)));
  box-shadow:var(--shadow-lg),inset 0 1.5px 0 rgba(255,255,255,.4);
  transform-origin:top left;will-change:transform,width,height;}
#detail::before{content:"";position:absolute;left:0;right:0;top:0;height:38%;background:linear-gradient(180deg,rgba(255,255,255,.4),transparent);pointer-events:none;}
#detail .d-in{position:relative;padding:clamp(24px,4vw,44px);height:100%;overflow:auto;opacity:0;transition:opacity calc(.35s*var(--mx)) var(--ease) calc(.18s*var(--mx));
  display:flex;flex-direction:column;gap:20px;}
#detail.open .d-in{opacity:1;}
#detail .d-head{display:flex;align-items:center;gap:16px;}
#detail .d-head juwel-entity{flex:none;}
#detail .d-k{font-family:var(--mono);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;opacity:.9;}
#detail .d-t{font-size:clamp(28px,4vw,40px);font-weight:900;letter-spacing:-.03em;line-height:1;margin-top:4px;}
#detail .d-close{position:absolute;top:18px;right:18px;width:44px;height:44px;border-radius:50%;border:none;cursor:pointer;z-index:3;
  background:rgba(255,255,255,.28);backdrop-filter:blur(8px);color:currentColor;display:grid;place-items:center;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.5);transition:transform .35s var(--bounce);}
#detail .d-close:hover{transform:rotate(90deg) scale(1.08);}
#detail .d-close svg{width:18px;height:18px;}
#detail .d-body{font-size:clamp(15px,1.8vw,17.5px);font-weight:500;line-height:1.55;max-width:58ch;opacity:.97;}
#detail .d-acts{display:flex;gap:12px;flex-wrap:wrap;}
#detail .d-acts .action{border:none;background:rgba(255,255,255,.92);color:var(--receipt-bg,#17101F);--paper-ink:#17101F;}
#detail .d-acts .action .a-k{color:rgba(23,16,31,.5);}
#detail .d-acts .action .a-t{color:#17101F;}
#detail .d-cta{margin-top:auto;display:flex;gap:12px;flex-wrap:wrap;}
#detail .cbtn.onglass{background:rgba(255,255,255,.95);color:#17101F;box-shadow:0 12px 30px -10px rgba(0,0,0,.35),inset 0 1px 0 #fff;}

/* scene 6 — lab */
#s-lab .lab-card{margin:44px auto 0;max-width:820px;background:var(--receipt-bg);color:var(--receipt-ink);border-radius:var(--r-2xl);
  padding:clamp(28px,4.5vw,52px);box-shadow:var(--shadow-lg);position:relative;overflow:hidden;text-align:left;}
#s-lab .lab-card::after{content:"";position:absolute;inset:auto -20% -55% -20%;height:110%;pointer-events:none;filter:blur(40px);opacity:.5;
  background:radial-gradient(50% 60% at 30% 100%,rgba(255,106,0,.5),transparent 70%),
             radial-gradient(50% 60% at 75% 100%,rgba(123,43,255,.55),transparent 70%);}
#s-lab .lab-k{font-family:var(--mono);font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--topaz);}
#s-lab .lab-card h3{font-size:clamp(24px,3.2vw,34px);font-weight:900;letter-spacing:-.03em;margin:14px 0 0;line-height:1.06;}
#s-lab .lab-card h3 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--amethyst);}
#s-lab .lab-card p{position:relative;font-size:clamp(15px,1.8vw,17.5px);line-height:1.6;color:rgba(239,231,245,.78);margin:16px 0 0;max-width:60ch;}
#s-lab .lab-card p b{color:#fff;font-weight:700;}
#s-lab .lab-cta{position:relative;margin-top:26px;display:flex;gap:12px;flex-wrap:wrap;align-items:center;}
#s-lab .lab-note{font-family:var(--mono);font-size:11.5px;color:rgba(239,231,245,.5);margin-top:20px;position:relative;}

/* scene 7 — pricing */
.price-grid{margin:46px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1020px;}
@media(max-width:880px){.price-grid{grid-template-columns:1fr;max-width:440px;}}
.price{background:var(--surface);border-radius:var(--r-xl);padding:28px 26px;text-align:left;
  box-shadow:var(--shadow),inset 0 0 0 1.5px var(--line-2);display:flex;flex-direction:column;gap:6px;
  transition:transform .45s var(--bounce),box-shadow .45s;}
.price:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg),inset 0 0 0 1.5px var(--line-2);}
.price.feat{background:linear-gradient(170deg,var(--accent-2),var(--accent-deep));color:#fff;position:relative;overflow:hidden;
  box-shadow:var(--shadow-lg),inset 0 1.5px 0 rgba(255,255,255,.45);}
.price.feat::before{content:"";position:absolute;left:0;right:0;top:0;height:44%;background:linear-gradient(180deg,rgba(255,255,255,.4),transparent);pointer-events:none;}
.price .p-name{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);}
.price.feat .p-name{color:rgba(255,255,255,.85);}
.price .p-amt{font-size:44px;font-weight:900;letter-spacing:-.04em;margin-top:6px;}
.price .p-amt span{font-size:16px;font-weight:600;color:var(--ink-3);letter-spacing:0;}
.price.feat .p-amt span{color:rgba(255,255,255,.8);}
.price .p-meta{font-size:14.5px;color:var(--ink-2);line-height:1.5;font-weight:500;}
.price.feat .p-meta{color:rgba(255,255,255,.94);}
.price .p-cta{margin-top:18px;}
.price-note{margin:26px auto 0;max-width:58ch;text-align:center;font-size:14px;color:var(--ink-3);line-height:1.55;}

/* footer */
footer{padding:70px 24px 60px;text-align:center;}
footer .f-gem{width:44px;height:44px;margin:0 auto;}
footer .f-line{margin-top:18px;font-weight:800;font-size:17px;letter-spacing:-.01em;}
footer .f-domains{margin:14px auto 0;display:flex;gap:10px;justify-content:center;flex-wrap:wrap;font-family:var(--mono);font-size:12px;color:var(--ink-3);}
footer .f-domains span{background:color-mix(in srgb,var(--surface) 75%,transparent);border:1px solid var(--line-2);border-radius:var(--r-full);padding:7px 14px;}
footer .f-domains b{color:var(--ink-2);font-weight:600;}
footer .f-legal{margin-top:22px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--ink-4);}

/* ── reveals (flow + non-pinned) ── */
[data-rv]{opacity:0;transform:translateY(26px) scale(.985);}
[data-rv].in{opacity:1;transform:none;transition:opacity calc(.7s*var(--mx)) var(--ease),transform calc(.85s*var(--mx)) var(--bounce);transition-delay:var(--d,0s);}
body.no-motion [data-rv]{opacity:1;transform:none;transition:none;}

/* ── sheet-pull (theme change) ── */
#sheet{position:fixed;inset:-2% -6% auto -6%;height:118vh;z-index:200;pointer-events:none;display:none;
  border-radius:0 0 44% 44%/0 0 90px 90px;box-shadow:0 40px 90px -30px rgba(0,0,0,.45);}
#sheet[data-look="light"]{background:radial-gradient(120% 90% at 10% -5%,#FFE7F0,transparent 55%),
  radial-gradient(120% 90% at 96% 0%,#E6F4FF,transparent 52%),
  radial-gradient(140% 130% at 50% 112%,#FFF1D9,transparent 60%),#FFF8FB;}
#sheet[data-look="dark"]{background:radial-gradient(120% 90% at 10% -5%,rgba(255,93,126,.16),transparent 55%),
  radial-gradient(120% 90% at 96% 0%,rgba(40,194,255,.14),transparent 52%),
  radial-gradient(140% 130% at 50% 112%,rgba(168,92,255,.16),transparent 60%),#140A1E;}
#sheet .grab{position:absolute;left:50%;bottom:-26px;width:64px;height:64px;transform:translateX(-50%);}
#sheet .grab img{width:100%;height:100%;filter:drop-shadow(0 10px 22px rgba(25,14,36,.4));}
.rebound{animation:rebound calc(.75s*var(--mx)) var(--bounce) both;animation-delay:var(--rbd,0s);}
@keyframes rebound{0%{transform:translateY(0);}30%{transform:translateY(14px) scale(.985);}70%{transform:translateY(-7px) scale(1.008);}100%{transform:none;}}

/* ── gooey droplets ── */
.droplet{position:fixed;z-index:300;width:12px;height:12px;border-radius:50%;pointer-events:none;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.6);}

/* jelly press — any tactile surface */
.jelly{animation:jelly calc(.55s*var(--mx)) var(--bounce);}
@keyframes jelly{0%{transform:scale(1);}30%{transform:scale(1.08,.9);}60%{transform:scale(.96,1.05);}100%{transform:scale(1);}}

/* ── entity component ── */
juwel-entity{display:inline-block;position:relative;width:var(--je,120px);height:var(--je,120px);
  cursor:pointer;-webkit-tap-highlight-color:transparent;}
juwel-entity .je-wrap{position:absolute;inset:0;will-change:transform;}
juwel-entity .je-float{position:absolute;inset:0;animation:jeFloat 6.5s ease-in-out infinite;}
juwel-entity[static] .je-float{animation:none;}
@keyframes jeFloat{0%,100%{transform:translateY(0) rotate(-1.6deg);}50%{transform:translateY(calc(var(--je,120px)*-.07)) rotate(1.6deg);}}
juwel-entity img{position:absolute;inset:0;width:100%;height:100%;opacity:0;transition:opacity .22s var(--ease);
  filter:drop-shadow(0 calc(var(--je,120px)*.12) calc(var(--je,120px)*.22) rgba(25,14,36,.35));user-select:none;-webkit-user-drag:none;}
juwel-entity img.on{opacity:1;}
juwel-entity .je-glow{position:absolute;inset:-34%;border-radius:50%;z-index:-1;pointer-events:none;
  background:radial-gradient(circle,color-mix(in srgb,var(--accent-deep) 34%,transparent),transparent 66%);
  filter:blur(10px);animation:jePulse 5.5s var(--ease) infinite;}
@keyframes jePulse{0%,100%{opacity:.75;transform:scale(1);}50%{opacity:1;transform:scale(1.1);}}
juwel-entity .je-blob{position:absolute;inset:6%;z-index:2;opacity:0;pointer-events:none;
  background:linear-gradient(140deg,var(--topaz),var(--garnet-2) 40%,var(--amethyst-2) 80%);
  filter:blur(3px) saturate(1.3);box-shadow:inset 0 3px 8px rgba(255,255,255,.55),0 14px 34px -12px rgba(168,92,255,.5);
  animation:jeBlob 3.2s ease-in-out infinite;}
@keyframes jeBlob{0%,100%{border-radius:52% 48% 60% 40%/48% 62% 38% 52%;}33%{border-radius:40% 60% 46% 54%/58% 42% 58% 42%;}66%{border-radius:58% 42% 52% 48%/42% 56% 44% 58%;}}
juwel-entity.forming .je-blob{opacity:1;}
juwel-entity.forming img{opacity:0!important;}
juwel-entity .je-pop{animation:jePop calc(.6s*var(--mx)) var(--bounce);}
@keyframes jePop{0%{transform:scale(.55);}60%{transform:scale(1.12);}100%{transform:scale(1);}}
juwel-entity.squish .je-wrap{animation:jeSquish calc(.5s*var(--mx)) var(--bounce);}
@keyframes jeSquish{0%{transform:scale(1);}35%{transform:scale(1.14,.82);}70%{transform:scale(.92,1.08);}100%{transform:scale(1);}}

/* hero entity sizing */
#heroEntity{--je:clamp(140px,17vw,220px);}
body[data-herolayout="split"] #s-hero .hero-stack{flex-direction:row;text-align:left;gap:clamp(28px,5vw,72px);align-items:center;}
body[data-herolayout="split"] #s-hero .hero-copy{display:flex;flex-direction:column;align-items:flex-start;}
body[data-herolayout="split"] #s-hero h1{max-width:13ch;}
body[data-herolayout="split"] #s-hero .t-lede{margin-left:0;}
body[data-herolayout="split"] #s-hero .hero-cta{justify-content:flex-start;}
body[data-herolayout="split"] #heroEntity{--je:clamp(180px,22vw,300px);}
@media(max-width:760px){body[data-herolayout="split"] #s-hero .hero-stack{flex-direction:column;text-align:center;}
  body[data-herolayout="split"] #s-hero .hero-copy{align-items:center;}
  body[data-herolayout="split"] #s-hero .hero-cta{justify-content:center;}}

/* floating parallax gems (background accents) — click to pop */
.pgem{position:absolute;border-radius:30%;opacity:.5;filter:blur(1px);pointer-events:auto;cursor:pointer;
  transition:opacity .18s var(--ease);
  background:linear-gradient(160deg,var(--g,var(--sapphire-2)),var(--gd,var(--sapphire-deep)));
  box-shadow:inset 0 2px 4px rgba(255,255,255,.5);}
html[data-theme="dark"] .pgem{opacity:.3;}

/* the receipt is tactile too */
#receipt{cursor:pointer;}

/* ── pull-back gem (overscroll at top) ── */
.pullgem{position:fixed;top:0;left:50%;width:78px;height:78px;z-index:150;pointer-events:none;opacity:0;will-change:transform;}
.pullgem img{width:100%;height:100%;filter:drop-shadow(0 14px 28px rgba(25,14,36,.42));}

/* ── living background canvas + stacking ── */
.liquid-bg{position:fixed;inset:0;z-index:0;pointer-events:none;}
#scroller{position:relative;z-index:1;}

/* ── LIQUID GLASS applied — the pane, the light, the lens ──
   (material recipe lives in juwel-ds.css as .lg) */
.inputbar,.menu-pop,.price:not(.feat),.prog,.note,.mem,.action{
  background:color-mix(in srgb,var(--surface) 50%,transparent);
  backdrop-filter:blur(22px) saturate(1.9);
  -webkit-backdrop-filter:blur(22px) saturate(1.9);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.55),
    inset 0 0 0 1px color-mix(in srgb,var(--line) 60%,transparent),
    0 24px 48px -26px color-mix(in srgb,var(--amethyst-deep) 26%,rgba(25,14,36,.35));}
html[data-theme="dark"] .inputbar,html[data-theme="dark"] .menu-pop,html[data-theme="dark"] .price:not(.feat),
html[data-theme="dark"] .prog,html[data-theme="dark"] .note,html[data-theme="dark"] .mem,html[data-theme="dark"] .action{
  background:color-mix(in srgb,var(--surface) 44%,transparent);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.16),
    inset 0 0 0 1px rgba(255,255,255,.07),
    0 28px 56px -28px rgba(0,0,0,.7);}
.inputbar,.action,.mem,.note,.price,.prog{overflow:hidden;position:relative;}
/* the lensing rim — gem light caught on the edge of the pane */
.inputbar::before,.price:not(.feat)::before,.prog::before,.note::before,.mem::before,.action::before,.menu-pop::before{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:1;
  padding:1.5px;
  background:linear-gradient(135deg,
    color-mix(in srgb,var(--topaz) 55%,transparent),
    color-mix(in srgb,var(--garnet-2) 30%,transparent) 30%,
    transparent 52%,
    color-mix(in srgb,var(--sapphire-2) 26%,transparent) 78%,
    color-mix(in srgb,var(--amethyst-2) 50%,transparent));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:.45;transition:opacity .5s var(--ease);}
.inputbar:hover::before,.price:not(.feat):hover::before,.prog:hover::before,.note:hover::before,.mem:hover::before,.action:hover::before{opacity:.9;}
html[data-theme="dark"] .inputbar::before,html[data-theme="dark"] .price:not(.feat)::before,html[data-theme="dark"] .prog::before,
html[data-theme="dark"] .note::before,html[data-theme="dark"] .mem::before,html[data-theme="dark"] .action::before,html[data-theme="dark"] .menu-pop::before{opacity:.35;}
/* specular sheen that glides across on hover — slow, like light on glass */
.action::after,.mem::after,.note::after,.price::after,.inputbar::after,.gemcard .g-sheen{content:"";position:absolute;inset:-30%;pointer-events:none;
  background:linear-gradient(115deg,transparent 42%,rgba(255,255,255,.26) 50%,transparent 58%);
  transform:translateX(-80%);transition:transform calc(1.4s*var(--mx)) var(--ease);}
.action:hover::after,.mem:hover::after,.note:hover::after,.price:hover::after,.inputbar:hover::after{transform:translateX(80%);}
html[data-theme="dark"] .action::after,html[data-theme="dark"] .mem::after,html[data-theme="dark"] .note::after,
html[data-theme="dark"] .price::after,html[data-theme="dark"] .inputbar::after{background:linear-gradient(115deg,transparent 42%,rgba(255,255,255,.12) 50%,transparent 58%);}
/* small chrome joins the material */
.eyebrow.pill,.verify-line,.icon-btn{
  background:color-mix(in srgb,var(--surface) 52%,transparent);
  backdrop-filter:blur(18px) saturate(1.8);
  -webkit-backdrop-filter:blur(18px) saturate(1.8);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.5),inset 0 0 0 1px color-mix(in srgb,var(--line) 55%,transparent),0 14px 30px -18px rgba(25,14,36,.35);}
html[data-theme="dark"] .eyebrow.pill,html[data-theme="dark"] .verify-line,html[data-theme="dark"] .icon-btn{
  box-shadow:inset 0 1px 0 rgba(255,255,255,.14),inset 0 0 0 1px rgba(255,255,255,.07),0 14px 30px -18px rgba(0,0,0,.6);}
.nav.scrolled{box-shadow:0 1px 0 var(--line-2),inset 0 1px 0 rgba(255,255,255,.35);}
html[data-theme="dark"] .nav.scrolled{box-shadow:0 1px 0 var(--line-2),inset 0 1px 0 rgba(255,255,255,.08);}

/* toast */
#toast{position:fixed;left:50%;bottom:28px;z-index:400;transform:translateX(-50%) translateY(80px);opacity:0;
  background:var(--receipt-bg);color:var(--receipt-ink);font-family:var(--mono);font-size:13px;
  border-radius:var(--r-full);padding:13px 22px;box-shadow:var(--shadow-lg);pointer-events:none;
  transition:transform calc(.55s*var(--mx)) var(--bounce),opacity .3s var(--ease);}
#toast.on{transform:translateX(-50%);opacity:1;}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  .je-float,.je-glow,.je-blob{animation:none!important;}
  [data-rv]{opacity:1;transform:none;transition:none;}
  .scrollcue i::after{animation:none;}
}
