@charset "UTF-8";.constellations-page-body{overflow:hidden;background-color:#f2f0ee;background-image:radial-gradient(ellipse 80% 60% at 15% 20%,rgba(232,122,171,.08) 0%,transparent 70%),radial-gradient(ellipse 70% 50% at 85% 75%,rgba(216,125,160,.07) 0%,transparent 65%),radial-gradient(ellipse 60% 50% at 50% 50%,rgba(91,159,214,.05) 0%,transparent 60%),radial-gradient(ellipse 40% 40% at 75% 20%,rgba(136,89,0,.04) 0%,transparent 55%)}.demos-nav-bar--constellation{background:transparent}.demos-nav-bar--constellation .demos-nav-link{color:#695d5d;border:none}.demos-nav-bar--constellation .demos-nav-link--active{color:#3e1212;border:none}.demos-nav-bar--constellation .demos-nav-link:not(.demos-nav-link--active):not(.demos-nav-link--external){color:#695d5d}.demos-nav-bar--constellation .demos-nav-link:not(.demos-nav-link--active):not(.demos-nav-link--external):hover{color:#968686}.constellation-viewport{position:fixed;inset:0;overflow:hidden;cursor:grab;-moz-user-select:none;user-select:none;-webkit-user-select:none;touch-action:none}.constellation-viewport--grabbing{cursor:grabbing}.constellation-canvas{position:absolute;top:0;left:0;transform-origin:0 0}.constellation-canvas-overlay{position:absolute;top:-500px;left:-500px;padding:500px;z-index:5;background:#f2f0ee8c;pointer-events:none;animation:constellationOverlayIn .35s ease}@keyframes constellationOverlayIn{0%{opacity:0}to{opacity:1}}.constellation-edges{position:absolute;top:0;left:0;z-index:1;pointer-events:none;overflow:visible}.constellation-edges--above{z-index:8}.constellation-edge{fill:none;stroke:#695d5d;stroke-width:1.5}.constellation-edge--highlighted{stroke:#3e1212;stroke-width:1.5}.constellation-node{position:absolute;z-index:3;display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;transform:translate(-50%,-16px);transition:transform .8s cubic-bezier(.22,1,.36,1)}.constellation-node--focused{z-index:8}.constellation-node--focused .constellation-node__circle{width:84px;height:84px;background:#d87da0}.constellation-node--focused .constellation-node__icon{width:88px;height:88px}.constellation-node--collection{opacity:1;z-index:7;animation:collection-pulse 1.8s ease-in-out infinite}.constellation-node--collection .constellation-node__circle{width:80px;height:80px;background:#4a94d6;box-shadow:0 0 18px #4a94d6b3,0 0 40px #4a94d64d}.constellation-node--collection .constellation-node__icon{width:88px;height:88px}.constellation-node--collection .constellation-node__label{font-weight:500}@keyframes collection-pulse{0%,to{filter:brightness(1)}50%{filter:brightness(1.15)}}.constellation-node__circle{width:64px;height:64px;border-radius:50%;background:#e87aab;-o-object-fit:contain;object-fit:contain;display:block;transition:width .3s ease,height .3s ease,background .3s ease;flex-shrink:0}.constellation-node__icon{width:76px;height:76px;-o-object-fit:contain;object-fit:contain;display:block;background:transparent;border:0;border-radius:0;box-shadow:none;flex-shrink:0;transition:width .3s ease,height .3s ease}.constellation-node__label{font-family:FormaDJRMono,FormaDJRDeck,monospace;font-size:30px;font-weight:400;color:#3d3636;text-transform:uppercase;text-align:center;letter-spacing:-.28px;line-height:normal;white-space:pre-wrap;max-width:420px}.constellation-tag-pill{position:absolute;z-index:4;transform:translate(-50%,-50%);display:flex;align-items:center;gap:12px;padding:20px 36px;background:#fff;border:2px dashed #543533;box-shadow:0 2px 10px #2719191a;white-space:nowrap;cursor:pointer;transition:opacity .3s ease,box-shadow .3s ease}.constellation-tag-pill--focused{z-index:8;box-shadow:0 4px 20px #27191933}.constellation-tag-pill__icon{width:37px;height:37px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.constellation-tag-pill__icon img,.constellation-tag-pill__icon svg{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.constellation-tag-pill__label{font-family:FormaDJRMono,FormaDJRDeck,monospace;font-size:35px;font-weight:400;color:#543533;text-transform:uppercase;text-align:center;letter-spacing:-.32px;line-height:1.12}.constellation-overlay{position:fixed;inset:0;z-index:120;background:#0a0c1b66;backdrop-filter:blur(5.4px);-webkit-backdrop-filter:blur(5.4px);display:flex;align-items:center;justify-content:center;animation:constellationFadeIn .4s ease}.constellation-overlay--hiding{animation:constellationFadeOut .4s ease forwards}@keyframes constellationFadeIn{0%{opacity:0}to{opacity:1}}@keyframes constellationFadeOut{0%{opacity:1}to{opacity:0}}.constellation-modal{position:relative;width:558px;aspect-ratio:826/450;background:#fff;border-radius:8px;box-shadow:0 2px 30px #00000008,0 2px 10.4px #0000000d,0 8px 32px #00000024,0 24px 64px #0000001a;overflow:hidden;text-align:center;padding:0;box-sizing:border-box}.constellation-modal__art{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}.constellation-modal__art-img{position:absolute;inset:0;width:100%;height:100%;-o-object-fit:fill;object-fit:fill;display:block}.constellation-modal__content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;height:100%;min-height:0;box-sizing:border-box;padding:48px 95px 40px}.constellation-modal__content>*{flex-shrink:0}.constellation-modal__text{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%}.constellation-modal__title{font-family:FormaDJRDeck,sans-serif;font-weight:500;font-size:clamp(1.2rem,2.6vw + .65rem,1.78125rem);color:#1d1717;margin:0;width:100%;text-align:center}.constellation-modal__desc{font-family:FormaDJRMono,FormaDJRDeck,monospace;font-size:clamp(.625rem,.9vw + .52rem,.71875rem);font-weight:400;color:#695d5d;letter-spacing:-.17px;text-transform:uppercase;line-height:1.25;margin:0 0 12px;width:100%;text-align:center}.constellation-modal__link{color:#695d5d;-webkit-text-decoration:underline;text-decoration:underline;text-decoration-style:wavy;text-decoration-color:#bdb0ad;text-underline-offset:3px;transition:color .15s}.constellation-modal__link:hover{color:#3d3636}.constellation-modal__btn{all:unset;cursor:pointer;box-sizing:border-box;display:flex;align-items:center;justify-content:center;flex-shrink:0;width:216px;min-height:41px;padding:10px 20px;height:auto;background:#fff;border:.5px dashed #5d3232;box-shadow:0 2px 2px #885900;font-family:FormaDJRDeck,sans-serif;font-weight:500;font-size:14px;color:#3e1212;text-transform:uppercase;letter-spacing:.28px;transition:background .15s,box-shadow .15s}.constellation-modal__btn:hover{background:#faf8f5;box-shadow:0 3px 4px #885900}.constellation-modal__btn:active{box-shadow:0 1px 1px #885900}.constellation-detail{position:fixed;top:calc(5rem + env(safe-area-inset-top) + 12px);left:52px;z-index:40;width:368px;box-sizing:border-box;background:#fff;border-radius:8px;padding:24px;box-shadow:0 2px 30px #00000008,0 2px 10.4px #0000000d;animation:constellationSlideIn .4s cubic-bezier(.22,1,.36,1);max-height:calc(100vh - (5rem + env(safe-area-inset-top)) - 60px);overflow-y:auto}.constellation-detail__nav{display:flex;flex-direction:column;gap:10px;margin:18px 0 0;flex-shrink:0}.constellation-detail__back{all:unset;align-self:flex-start;font-family:FormaDJRMono,FormaDJRDeck,monospace;font-size:11.5px;color:#635757;cursor:pointer;letter-spacing:-.17px;padding:4px 0;transition:opacity .15s}.constellation-detail__back:hover{opacity:.8}.constellation-detail__stepper{display:flex;align-items:stretch;justify-content:space-between;gap:8px}.constellation-detail__step{all:unset;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;min-height:40px;min-width:72px;padding:0 14px;font-family:FormaDJRMono,FormaDJRDeck,monospace;font-size:12px;font-weight:400;color:#635757;cursor:pointer;letter-spacing:-.17px;border-radius:6px;border:.5px solid rgba(99,87,87,.28);background:#fff;box-shadow:0 1px 2px #0000000d;transition:border-color .15s,color .15s,box-shadow .15s}.constellation-detail__step:hover{background:#fff;border-color:#6357576b;color:#3d3636;box-shadow:0 2px 4px #0000000f}.constellation-detail__step:active{box-shadow:0 1px 1px #0000000d}.constellation-detail__step:focus-visible{outline:2px solid rgba(99,87,87,.35);outline-offset:2px}.constellation-detail__count{flex:1;min-width:0;text-align:center;align-self:center;font-family:FormaDJRMono,FormaDJRDeck,monospace;font-size:11.5px;color:#968686;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.constellation-detail--hiding{animation:constellationSlideOut .4s cubic-bezier(.22,1,.36,1) forwards}@keyframes constellationSlideIn{0%{opacity:0;transform:translateY(10px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes constellationSlideOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(8px) scale(.97)}}.constellation-detail__handle{display:none}.constellation-detail__handle-bar{width:36px;height:4px;border-radius:2px;background:#c4bbb8}.constellation-detail__inner{display:flex;flex-direction:column;gap:20px}.constellation-detail__img-wrap{border-radius:6px;overflow:hidden;aspect-ratio:318/187}.constellation-detail__img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.constellation-detail__body{display:flex;flex-direction:column;gap:18px;padding:0 4px}.constellation-detail__text{display:flex;flex-direction:column;gap:18px}.constellation-detail__title{font-family:FormaDJRDeck,sans-serif;font-weight:500;font-size:24px;color:#122126;letter-spacing:-.3px;line-height:normal;margin:0}.constellation-detail__desc{font-family:FormaDJRDeck,sans-serif;font-weight:400;font-size:13px;color:#695d5d;letter-spacing:.06px;line-height:1.4;margin:0}.constellation-detail__links-section{display:flex;flex-direction:column;gap:14px}.constellation-detail__links-label{font-family:FormaDJRMono,FormaDJRDeck,monospace;font-weight:500;font-size:11.5px;color:#1d1717;text-transform:uppercase}.constellation-detail__links-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:row;flex-wrap:wrap;gap:4px 16px}.constellation-detail__link-item{display:flex;align-items:center;gap:4px}.constellation-detail__link-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0}.constellation-detail__link-icon svg{width:13px;height:13px}.constellation-detail__link-text{font-family:FormaDJRDeck,sans-serif;font-weight:400;font-size:12px;color:#695d5d;letter-spacing:.06px;-webkit-text-decoration:none;text-decoration:none;transition:color .15s}.constellation-detail__link-text:hover{color:#3d3636}.constellation-rabbithole{position:fixed;top:calc(5rem + env(safe-area-inset-top) + 12px);left:52px;z-index:30;width:368px;height:106px;background:#fff;border-radius:8px;box-shadow:0 2px 30px #00000008,0 2px 10.4px #0000000d;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:box-shadow .15s}.constellation-rabbithole:hover{box-shadow:0 2px 30px #0000000f,0 2px 10.4px #00000014}.constellation-rabbithole__inner{display:flex;align-items:center;gap:6px}.constellation-rabbithole__icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center}.constellation-rabbithole__icon img,.constellation-rabbithole__icon svg{width:100%;height:100%}.constellation-rabbithole__text{font-family:FormaDJRMono,FormaDJRDeck,monospace;font-size:11.5px;font-weight:400;color:#695d5d;letter-spacing:-.17px}.constellation-bottom-bar{position:fixed;bottom:24px;left:52px;right:52px;z-index:30;display:flex;align-items:center;justify-content:space-between;pointer-events:none}.constellation-bottom-bar a,.constellation-bottom-bar button{pointer-events:auto}.constellation-bottom-bar__left{font-family:FormaDJRMono,FormaDJRDeck,monospace;font-size:11.5px;font-weight:400;color:#635757;letter-spacing:-.17px}.constellation-bottom-bar__about-btn{background:none;border:none;padding:0;cursor:pointer;transition:opacity .15s ease}.constellation-bottom-bar__about-btn:hover{opacity:.7}.constellation-about-wrap{position:relative;pointer-events:auto}.constellation-about-tip{position:absolute;bottom:calc(100% + 10px);left:0;width:-moz-max-content;width:max-content;max-width:260px;background:#fffcf8;border:.5px solid rgba(99,87,87,.2);border-radius:6px;padding:12px 14px;box-shadow:0 4px 16px #00000014,0 1px 3px #0000000f;display:flex;flex-direction:column;gap:6px;animation:aboutTipIn .15s ease;z-index:40}@keyframes aboutTipIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.constellation-about-tip__text{font-family:FormaDJRMono,FormaDJRDeck,monospace;font-size:10.5px;font-weight:400;color:#695d5d;letter-spacing:-.17px;text-transform:uppercase;line-height:1.5;margin:0}.constellation-about-tip__link{color:#695d5d;-webkit-text-decoration:underline;text-decoration:underline;text-decoration-style:wavy;text-decoration-color:#bdb0ad;text-underline-offset:3px;transition:color .15s}.constellation-about-tip__link:hover{color:#3d3636}.constellation-bottom-bar__right-group{display:flex;align-items:center;gap:24px}.constellation-bottom-bar__lucky,.constellation-bottom-bar__collection{all:unset;display:flex;align-items:center;gap:6px;cursor:pointer;transition:opacity .15s ease}.constellation-bottom-bar__lucky:hover,.constellation-bottom-bar__collection:hover{opacity:.7}.constellation-bottom-bar__collection--active .constellation-bottom-bar__collection-star,.constellation-bottom-bar__collection--active .constellation-bottom-bar__about-text{color:#5b9fd6}.constellation-bottom-bar__collection-wrap{position:relative;pointer-events:auto}.constellation-bottom-bar__collection-wrap:hover .constellation-bottom-bar__collection-tooltip{opacity:1;transform:translate(-50%) translateY(0)}.constellation-bottom-bar__collection-tooltip{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%) translateY(4px);width:-moz-max-content;width:max-content;background:#fffcf8;border:.5px solid rgba(99,87,87,.2);border-radius:6px;padding:8px 12px;box-shadow:0 4px 16px #00000014,0 1px 3px #0000000f;font-family:FormaDJRMono,FormaDJRDeck,monospace;font-size:10.5px;font-weight:400;color:#695d5d;letter-spacing:-.17px;text-transform:uppercase;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:40}.constellation-bottom-bar__collection-star{font-size:13px;color:#635757;transition:color .2s ease}.constellation-bottom-bar__lucky-star{font-size:13px;color:#635757}.constellation-bottom-bar__about-text{font-family:FormaDJRMono,FormaDJRDeck,monospace;font-size:11.5px;font-weight:400;color:#635757;letter-spacing:-.17px}.constellation-blur{position:fixed;z-index:20;pointer-events:none}.constellation-blur--left{top:0;left:0;width:120px;height:100vh;background:linear-gradient(to right,rgba(242,240,238,.85),transparent)}.constellation-blur--right{top:0;right:0;width:120px;height:100vh;background:linear-gradient(to left,rgba(242,240,238,.85),transparent)}.constellation-blur--top{top:0;left:0;right:0;height:120px;background:linear-gradient(to bottom,rgba(242,240,238,.85),transparent)}.constellation-blur--bottom{bottom:0;left:0;right:0;height:120px;background:linear-gradient(to top,rgba(242,240,238,.85),transparent)}@media(max-width:820px){.constellation-detail,.constellation-rabbithole{left:24px;width:320px}.constellation-bottom-bar{left:24px;right:24px}}@media(max-width:640px){.constellation-node__circle{width:74px;height:74px}.constellation-node__icon{width:86px;height:86px}.constellation-node__label{font-size:22px;letter-spacing:-.18px;max-width:300px}.constellation-detail{inset:auto 0 0;width:auto;max-height:88dvh;border-radius:16px 16px 0 0;padding:4px 20px calc(32px + env(safe-area-inset-bottom,0px));animation-name:constellationSheetUp;animation-duration:.38s;animation-timing-function:cubic-bezier(.22,1,.36,1);box-shadow:0 -2px 30px #00000014,0 -2px 10px #0000000a;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;will-change:transform;transition:transform .3s cubic-bezier(.22,1,.36,1)}.constellation-detail__handle{display:flex;align-items:center;justify-content:center;padding:4px 0 10px;cursor:grab;touch-action:none}.constellation-detail__nav{display:none}.constellation-detail__inner{gap:12px}.constellation-detail__img-wrap{aspect-ratio:16/8;max-height:28dvh;flex-shrink:0}.constellation-detail__body{gap:14px;padding:0 2px}.constellation-detail__text{gap:6px}.constellation-detail__title{font-size:18px}.constellation-detail__desc{font-size:11.5px}.constellation-detail__links-list{gap:4px 14px}.constellation-detail--hiding{animation-name:constellationSheetDown}@keyframes constellationSheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes constellationSheetDown{0%{transform:translateY(0)}to{transform:translateY(100%)}}.constellation-overlay{padding:12px;align-items:center;box-sizing:border-box}.constellation-modal{width:min(558px,100vw - 24px);max-height:90dvh;aspect-ratio:auto;overflow-y:auto;-webkit-overflow-scrolling:touch}.constellation-modal__content{padding:max(32px,min(8vw,48px)) max(20px,min(6vw,32px)) max(28px,min(7vw,40px));height:auto;min-height:0;justify-content:center;gap:max(14px,min(3.5vw,20px))}.constellation-modal__btn{width:min(216px,100%);min-height:44px;padding:12px 24px}.constellation-rabbithole{top:auto;bottom:max(16px,env(safe-area-inset-bottom,0px));left:16px;right:16px;width:auto;height:48px;border-radius:24px;background:#ffffffeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.constellation-bottom-bar{display:none}}
