.sphere-root{--radius:520px;--viewer-pad:72px;--circ:calc(var(--radius)*3.14);--rot-y:calc((360deg/var(--segments-x))/2);--rot-x:calc((360deg/var(--segments-y))/2);--item-width:calc(var(--circ)/var(--segments-x));--item-height:calc(var(--circ)/var(--segments-y));height:100%;position:relative;width:100%}.sphere-root *{box-sizing:border-box}.item,.item__image,.sphere{transform-style:preserve-3d}main.sphere-main{background:#0000;display:grid;inset:0;overflow:hidden;place-items:center;position:absolute;touch-action:none;user-select:none;-webkit-user-select:none}.stage{contain:layout paint size;display:grid;height:100%;perspective:calc(var(--radius)*2);perspective-origin:50% 50%;place-items:center;transform:scale(1.6) translateY(-5%);width:100%}.sphere{transform:translateZ(calc(var(--radius)*-1));will-change:transform}.overlay,.overlay--blur{inset:0;margin:auto;pointer-events:none;position:absolute;z-index:3}.overlay{background-image:radial-gradient(#ebebeb00 65%,#fff 100%);background-image:radial-gradient(#ebebeb00 65%,var(  --overlay-blur-color,#fff) 100%)}.overlay--blur{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);-webkit-mask-image:radial-gradient(#ebebeb00 70%,#fff 90%);-webkit-mask-image:radial-gradient(#ebebeb00 70%,var(--overlay-blur-color,#fff) 90%);mask-image:radial-gradient(#ebebeb00 70%,#fff 90%);mask-image:radial-gradient(#ebebeb00 70%,var(--overlay-blur-color,#fff) 90%)}.item{bottom:-999px;height:calc(var(--item-height)*var(--item-size-y));left:-999px;margin:auto;right:-999px;top:-999px;transform:rotateY(calc(var(--rot-y)*(var(--offset-x) + ((var(--item-size-x) - 1)/2)))) rotateX(calc(var(--rot-x)*(var(--offset-y) - ((var(--item-size-y) - 1)/2)))) translateZ(var(--radius));transform:rotateY(calc(var(--rot-y)*(var(--offset-x) + ((var(--item-size-x) - 1)/2)) + var(--rot-y-delta, 0deg))) rotateX(calc(var(--rot-x)*(var(--offset-y) - ((var(--item-size-y) - 1)/2)) + var(--rot-x-delta, 0deg))) translateZ(var(--radius));transform-origin:50% 50%;width:calc(var(--item-width)*var(--item-size-x))}.item,.item__image{backface-visibility:hidden;position:absolute;transition:transform .3s}.item__image{-webkit-tap-highlight-color:transparent;background:#0000;border-radius:12px;border-radius:var(--tile-radius,12px);cursor:pointer;display:block;inset:2px;overflow:hidden;pointer-events:auto;touch-action:manipulation;transform:translateZ(0)}.item__image:focus{outline:none}.item__image img{backface-visibility:hidden;filter:none;filter:var(--image-filter,none);height:100%;object-fit:cover;pointer-events:none;width:100%}.viewer{align-items:center;display:flex;inset:0;justify-content:center;padding:var(--viewer-pad);pointer-events:none;position:absolute;z-index:20}.viewer .frame{aspect-ratio:1;border-radius:32px;border-radius:var(--enlarge-radius,32px);display:flex;height:100%}@media (max-aspect-ratio:1/1){.viewer .frame{height:auto;width:100%}}.viewer .scrim{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0006;inset:0;opacity:0;pointer-events:none;position:absolute;transition:opacity .5s ease;z-index:10}.sphere-root[data-enlarging=true] .viewer .scrim{opacity:1;pointer-events:all}.viewer .enlarge{border-radius:32px;border-radius:var(--enlarge-radius,32px);box-shadow:0 10px 30px #00000059;overflow:hidden;position:absolute;transform-origin:top left;transition:transform .5s ease,opacity .5s ease;z-index:30}.viewer .enlarge img{height:100%;object-fit:cover;width:100%}.sphere-root .enlarge-closing img,.viewer .enlarge img{filter:none;filter:var(--image-filter,none)}.hint-toast{animation:hint-fade 3.5s ease forwards;background:#00000073;border-radius:999px;color:#fff;font-size:13px;left:50%;letter-spacing:.03em;padding:8px 18px;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);white-space:nowrap;z-index:10}@keyframes hint-fade{0%{opacity:0}20%{opacity:1}70%{opacity:1}to{opacity:0}}.edge-fade{background:linear-gradient(180deg,#0000,#fff);background:linear-gradient(to bottom,#0000,var(--overlay-blur-color,#fff));height:120px;left:0;pointer-events:none;position:absolute;right:0;z-index:5}.edge-fade--top{top:0;transform:rotate(180deg)}.edge-fade--bottom{bottom:0}.gate{background:#fff;inset:0;justify-content:center;position:fixed}.gate,.gate__card{align-items:center;display:flex}.gate__card{flex-direction:column;gap:24px}.gate__label{color:#999;font-family:Georgia,serif;font-size:18px;letter-spacing:.04em;margin:0}.gate__form{align-items:center;display:flex;gap:6px}@keyframes shake{0%,to{transform:translateX(0)}20%{transform:translateX(-8px)}40%{transform:translateX(8px)}60%{transform:translateX(-6px)}80%{transform:translateX(6px)}}.gate__form--shake{animation:shake .45s ease}.gate__input{-moz-appearance:textfield;background:#0000;border:none;border-bottom:1.5px solid #ccc;color:#222;font-family:Georgia,serif;font-size:20px;outline:none;padding:10px 8px;text-align:center;width:52px}.gate__input::-webkit-inner-spin-button,.gate__input::-webkit-outer-spin-button{-webkit-appearance:none}.gate__input:focus{border-bottom-color:#222}.gate__input--year{width:76px}.gate__sep{color:#ccc;font-family:Georgia,serif;font-size:20px;-webkit-user-select:none;user-select:none}.gate__btn{align-items:center;background:none;border:1.5px solid #222;border-radius:50%;color:#222;cursor:pointer;display:flex;font-size:16px;height:38px;justify-content:center;margin-left:12px;transition:background .2s,color .2s;width:38px}.gate__btn:hover{background:#222;color:#fff}.list{height:100%;position:relative;width:100%}.item-wrapper{cursor:pointer;left:0;padding:6px;position:absolute;top:0;will-change:transform,width,height,opacity}.item-wrapper>.item-img{background-position:50%;background-size:cover;border-radius:10px;box-shadow:0 10px 50px -10px #0003;font-size:10px;height:100%;line-height:10px;position:relative;text-transform:uppercase;width:100%}.scroll-reveal{margin:20px 0}.scroll-reveal-text{font-family:Times New Roman,Times,serif;font-size:clamp(1.6rem,4vw,3rem);font-weight:400;line-height:1.5}.word{display:inline}.letter{background:#fff;height:100dvh;overflow-y:scroll;width:100vw}.letter__track{height:400dvh}.letter__track--short{height:200dvh}.letter__sticky{align-items:center;box-sizing:border-box;display:flex;height:100dvh;justify-content:center;padding:48px;position:sticky;top:0}.letter__text{color:#111;font-size:clamp(20px,5vw,36px);font-weight:400;line-height:1.5;margin:0;max-width:600px;text-align:center}.letter__hint,.letter__text{font-family:Times New Roman,Times,serif}.letter__hint{animation:hint-bob 2s ease-in-out infinite;bottom:calc(32px + env(safe-area-inset-bottom));color:#aaa;font-size:25px;left:50%;letter-spacing:.06em;opacity:1;pointer-events:none;position:fixed;transform:translateX(-50%);transition:opacity 1.2s ease;white-space:nowrap}.letter__hint--hidden{animation:none;opacity:0}@keyframes hint-bob{0%,to{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-6px)}}.letter__cursor{animation:blink .7s step-end infinite;background:#111;display:inline-block;height:1.1em;margin-left:2px;vertical-align:text-bottom;width:2px}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.letter__break{height:100dvh}.letter__masonry{box-sizing:border-box;min-height:1200px;opacity:0;padding:0 12px;transition:opacity .4s ease;width:100%}.letter__masonry--visible{opacity:1}.letter__img-track{height:900dvh}.letter__img-sticky{animation:fade-in .8s ease both;display:flex;flex-direction:column;height:100dvh;overflow:hidden;position:sticky;top:0}.letter__img-top{box-sizing:border-box;flex-shrink:0;padding:0 12px}.letter__img-top img{border-radius:10px;width:100%}.letter__img-text{box-sizing:border-box;flex:1 1;overflow:hidden;padding:16px 24px}@keyframes fade-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.letter__closing{align-items:center;animation:fade-in .8s ease both;display:flex;flex-direction:column;padding:80px 48px 60px}.letter__closing-text{font-size:clamp(18px,4.5vw,28px);line-height:1.6;margin:0 0 24px;max-width:540px}.letter__closing-sig,.letter__closing-text{color:#111;font-family:Times New Roman,Times,serif;text-align:center}.letter__closing-sig{font-size:clamp(20px,5vw,32px);margin:16px 0 0}.letter__footer{margin-top:48px;width:100%}.letter__footer img{display:block;width:100%}.letter__spacer{height:100dvh}.open-btn{backdrop-filter:blur(12px) saturate(1.8);-webkit-backdrop-filter:blur(12px) saturate(1.8);background:#fff3;border:none;border-radius:999px;color:#fff;cursor:pointer;font-family:Times New Roman,Times,serif;font-size:20px;font-weight:400;letter-spacing:.04em;padding:14px 28px;white-space:nowrap}.bloom{background:#fff;inset:0;pointer-events:none;position:fixed;transform-origin:center;z-index:99999}.bloom--in{animation:bloom-in .2s ease-in forwards}.bloom--out{animation:bloom-out .2s ease-out forwards}@keyframes bloom-in{0%{border-radius:50%;opacity:0;transform:scale(.1)}to{border-radius:0;opacity:1;transform:scale(4)}}@keyframes bloom-out{0%{border-radius:0;opacity:1;transform:scale(4)}to{border-radius:50%;opacity:0;transform:scale(.1)}}
/*# sourceMappingURL=main.a1b57c7c.css.map*/