.glass-surface{position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:opacity .26s ease-out}.glass-surface__filter{position:absolute;inset:0;z-index:-1;width:100%;height:100%;opacity:0;pointer-events:none}.glass-surface__content{position:relative;z-index:1;display:flex;width:100%;height:100%;align-items:center;justify-content:center;padding:.5rem;border-radius:inherit}.glass-surface--svg{background:hsl(0 0% 100% / var(--glass-frost, 0));-webkit-backdrop-filter:var(--filter-id, url(#glass-filter)) saturate(var(--glass-saturation, 1));backdrop-filter:var(--filter-id, url(#glass-filter)) saturate(var(--glass-saturation, 1));box-shadow:0 0 2px 1px color-mix(in oklch,black,transparent 85%) inset,0 0 10px 4px color-mix(in oklch,black,transparent 90%) inset,0 4px 16px #11111a0d,0 8px 24px #11111a0d,0 16px 56px #11111a0d}.glass-surface--fallback{border:1px solid rgba(255,255,255,.34);background:#ffffff40;backdrop-filter:blur(12px) saturate(1.8) brightness(1.1);-webkit-backdrop-filter:blur(12px) saturate(1.8) brightness(1.1);box-shadow:0 8px 32px #8f5b7529,0 2px 16px #8f5b751a,inset 0 1px #ffffff75,inset 0 -1px #fff3}@supports not (backdrop-filter: blur(10px)){.glass-surface--fallback{background:#ffffff6b}.glass-surface--fallback:before{position:absolute;inset:0;z-index:-1;border-radius:inherit;background:#ffffff26;content:""}}.pc-card-wrapper{--pointer-x: 50%;--pointer-y: 50%;--pointer-from-center: 0;--pointer-from-top: .5;--pointer-from-left: .5;--card-opacity: 0;--rotate-x: 0deg;--rotate-y: 0deg;--background-x: 50%;--background-y: 50%;--grain: none;--icon: none;--behind-glow-color: rgba(248, 201, 216, .62);--behind-glow-size: 54%;--inner-gradient: linear-gradient(145deg, rgba(248, 201, 216, .78), rgba(217, 199, 242, .62));--card-radius: 30px;position:relative;width:min(100%,440px);margin-inline:auto;perspective:900px;touch-action:pan-y;transform:translateZ(.1px)}.pc-behind{position:absolute;inset:8%;z-index:0;pointer-events:none;background:radial-gradient(circle at var(--pointer-x) var(--pointer-y),var(--behind-glow-color) 0%,transparent var(--behind-glow-size));filter:blur(42px) saturate(1.12);opacity:calc(.74 * var(--card-opacity) + .28);transition:opacity .2s ease}.pc-card-wrapper:hover,.pc-card-wrapper:focus-within,.pc-card-wrapper.active{--card-opacity: 1}.pc-card-shell{position:relative;z-index:1}.pc-card{position:relative;display:grid;aspect-ratio:.78;width:100%;max-height:min(70vh,560px);overflow:hidden;border:10px solid rgba(255,253,249,.78);border-radius:var(--card-radius);background:#fffdf980;box-shadow:0 28px 70px #8f5b7533,#61495747 calc((var(--pointer-from-left) * 12px) - 4px) calc((var(--pointer-from-top) * 18px) - 6px) 22px -8px;transform:translateZ(0) rotateX(0) rotateY(0);transition:transform .48s ease,box-shadow .24s ease;backface-visibility:hidden}.pc-card-shell.active .pc-card,.pc-card:hover,.pc-card:focus-within{transform:translateZ(0) rotateX(var(--rotate-y)) rotateY(var(--rotate-x));transition:transform 80ms ease-out,box-shadow .16s ease}.pc-card *{display:grid;grid-area:1 / -1;border-radius:inherit;pointer-events:none}.pc-inside{position:absolute;inset:0;background-image:var(--inner-gradient)}.pc-shine{z-index:3;opacity:calc(.35 + var(--pointer-from-center) * .32);background:linear-gradient(115deg,transparent 8%,rgba(255,255,255,.12) 28%,rgba(231,199,119,.24) 42%,rgba(217,199,242,.2) 58%,transparent 78%),radial-gradient(circle at var(--pointer-x) var(--pointer-y),rgba(255,255,255,.42),transparent 36%);background-position:var(--background-x) var(--background-y),center;mix-blend-mode:screen;transition:opacity .22s ease}.pc-glare{z-index:4;opacity:.5;background-image:radial-gradient(farthest-corner circle at var(--pointer-x) var(--pointer-y),rgba(255,255,255,.42) 0%,rgba(248,201,216,.16) 26%,rgba(89,69,80,.28) 100%);mix-blend-mode:soft-light}.pc-avatar-content{z-index:2;overflow:hidden}.pc-avatar-content .avatar{position:absolute;inset:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transform:translate(calc((var(--pointer-from-left) - .5) * 10px)) translateY(calc((var(--pointer-from-top) - .5) * 8px)) scale(1.045);transition:transform .14s ease-out;will-change:transform}.pc-avatar-content:after{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(255,253,249,.1) 0%,transparent 44%,rgba(65,42,56,.44) 100%),radial-gradient(circle at 50% 12%,rgba(255,255,255,.22),transparent 32%);content:""}.pc-user-info{position:absolute;left:18px;right:18px;bottom:18px;z-index:5;display:flex;align-items:center;justify-content:space-between;gap:.8rem;border:1px solid rgba(255,255,255,.34);border-radius:22px;background:#fffdf92e;padding:.75rem;box-shadow:0 16px 34px #402d3829;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);pointer-events:auto}.pc-user-details{display:flex;min-width:0;align-items:center;gap:.72rem}.pc-mini-avatar{width:42px;height:42px;flex:0 0 auto;overflow:hidden;border:2px solid rgba(255,253,249,.64);border-radius:999px;box-shadow:0 8px 18px #402d382e}.pc-mini-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.pc-user-text{display:flex;min-width:0;flex-direction:column;gap:.3rem}.pc-handle,.pc-status{overflow:hidden;color:#fffdf9f0;text-overflow:ellipsis;white-space:nowrap;text-shadow:0 1px 14px rgba(64,45,56,.45)}.pc-handle{font-size:.9rem;font-weight:700}.pc-status{font-size:.78rem;opacity:.86}.pc-contact-btn{min-height:2.45rem;border:1px solid rgba(255,253,249,.45);border-radius:999px;background:#fffdf938;padding:0 .9rem;color:#fffdf9;font-size:.82rem;font-weight:700;text-shadow:0 1px 10px rgba(64,45,56,.42);transition:transform .16s ease,background .16s ease;pointer-events:auto}.pc-contact-btn:hover,.pc-contact-btn:focus-visible{transform:translateY(-1px);background:#fffdf957;outline:none}.pc-content:not(.pc-avatar-content){z-index:5;transform:translate3d(calc(var(--pointer-from-left) * -6px + 3px),calc(var(--pointer-from-top) * -6px + 3px),.1px)}.pc-details{position:absolute;top:clamp(1.5rem,5vw,2.3rem);left:1.2rem;right:1.2rem;display:flex;flex-direction:column;align-items:center;gap:.42rem;text-align:center}.pc-details h3,.pc-details p{display:block;grid-area:auto;margin:0;color:#fffdf9;text-shadow:0 2px 18px rgba(64,45,56,.48)}.pc-details h3{font-family:Georgia,Times New Roman,serif;font-size:clamp(2rem,5vw,3.2rem);font-weight:700;line-height:1.05}.pc-details p{font-size:clamp(.9rem,2.5vw,1.1rem);letter-spacing:.08em;line-height:1.35}.birthday-profile-card .pc-details{top:clamp(1.45rem,4vw,2.05rem);gap:.5rem}.birthday-profile-card .pc-details h3{font-size:clamp(2rem,4.4vw,3rem)}.birthday-profile-card .pc-details p{max-width:12rem;margin-inline:auto;font-size:clamp(.86rem,1.6vw,1.02rem)}@media(max-width:767px){.pc-card-wrapper{width:min(100%,360px);touch-action:pan-y}.pc-card{border-width:7px;border-radius:26px;max-height:520px}.pc-user-info{left:12px;right:12px;bottom:12px;border-radius:18px;padding:.58rem}.pc-mini-avatar{width:32px;height:32px}.pc-handle{font-size:.8rem}.pc-status{font-size:.68rem}.pc-contact-btn{min-height:2.25rem;padding:0 .74rem;font-size:.74rem}}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,ui-sans-serif,system-ui,PingFang SC,Microsoft YaHei,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.pointer-events-none{pointer-events:none}.absolute{position:absolute}.inset-0{inset:0}.mx-auto{margin-left:auto;margin-right:auto}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-8{margin-bottom:2rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.table{display:table}.hidden{display:none}.h-full{height:100%}.min-h-screen{min-height:100vh}.w-full{width:100%}.max-w-2xl{max-width:42rem}.max-w-7xl{max-width:80rem}.max-w-xl{max-width:36rem}@keyframes rise{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.animate-rise{animation:rise .8s ease-out both}@keyframes twinkle{0%,to{opacity:.35;transform:scale(.9)}50%{opacity:1;transform:scale(1.12)}}.animate-twinkle{animation:twinkle 3.6s ease-in-out infinite}.overflow-hidden{overflow:hidden}.overflow-x-hidden{overflow-x:hidden}.bg-cream{--tw-bg-opacity: 1;background-color:rgb(255 249 242 / var(--tw-bg-opacity, 1))}.object-cover{-o-object-fit:cover;object-fit:cover}.text-center{text-align:center}.font-serif{font-family:Georgia,Songti SC,STSong,Noto Serif SC,serif}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-base{font-size:1rem;line-height:1.5rem}.text-sm{font-size:.875rem;line-height:1.25rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.leading-7{line-height:1.75rem}.leading-8{line-height:2rem}.tracking-\[0\.16em\]{letter-spacing:.16em}.tracking-\[0\.18em\]{letter-spacing:.18em}.tracking-\[0\.2em\]{letter-spacing:.2em}.text-champagne{--tw-text-opacity: 1;color:rgb(231 199 119 / var(--tw-text-opacity, 1))}.text-ink{--tw-text-opacity: 1;color:rgb(89 69 80 / var(--tw-text-opacity, 1))}.text-ink\/55{color:#5945508c}.text-ink\/70{color:#594550b3}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.\[animation-delay\:0\.12s\]{animation-delay:.12s}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;background:radial-gradient(circle at 15% 10%,rgba(248,201,216,.58),transparent 28rem),radial-gradient(circle at 80% 0%,rgba(217,199,242,.5),transparent 24rem),linear-gradient(135deg,#fff9f2,#fce7ef 48%,#f0e8ff);color:#594550}.site-header{position:fixed;top:0;left:0;right:0;z-index:40;padding:.7rem clamp(.85rem,3vw,1.6rem);transition:background .18s ease,box-shadow .18s ease,backdrop-filter .18s ease}.site-header.is-scrolled{border-bottom:1px solid rgba(255,255,255,.62);background:#fffdf9c2;box-shadow:0 10px 28px #8f5b751a;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.site-header-inner{display:grid;grid-template-columns:minmax(150px,1fr) auto minmax(150px,1fr);align-items:center;gap:1rem;max-width:1180px;margin:0 auto}.site-brand{min-height:2.65rem;border:0;background:transparent;color:#594550;font-family:Georgia,Times New Roman,serif;font-size:clamp(.9rem,2.4vw,1.02rem);text-align:left}.desktop-nav{display:flex;align-items:center;justify-content:center;gap:.2rem;border:1px solid rgba(255,255,255,.62);border-radius:999px;background:#ffffff6b;padding:.25rem;box-shadow:0 12px 30px #8f5b7514}.nav-link{display:inline-flex;min-height:2.25rem;align-items:center;gap:.34rem;border-radius:999px;padding:0 .85rem;color:#594550ad;font-size:.9rem;text-decoration:none;transition:background .16s ease,color .16s ease,transform .16s ease}.nav-link:hover,.nav-link:focus-visible,.nav-link.is-active{background:#fffdf9d1;color:#594550;outline:none}.nav-link.is-locked{color:#5945506b}.nav-lock{font-size:.68rem;color:#b99a49}.header-actions{display:flex;align-items:center;justify-content:flex-end;gap:.55rem}.music-toggle{display:inline-flex;min-height:2.55rem;align-items:center;gap:.45rem;border:1px solid rgba(255,255,255,.75);border-radius:999px;background:#fff9;padding:0 .95rem;color:#594550;font-size:.88rem;box-shadow:0 12px 28px #8f5b7514}.music-toggle.is-compact{min-width:4.7rem;padding:0 .75rem}.music-note{color:#59455085}.progress-pill{display:inline-flex;min-height:2.45rem;align-items:center;justify-content:center;border:1px solid rgba(231,199,119,.42);border-radius:999px;background:#fffdf9ad;padding:0 .86rem;color:#594550;font-size:.9rem;font-weight:600;box-shadow:0 10px 26px #8f5b7514}.progress-pill.is-large{min-height:2.75rem;padding:0 1.2rem;font-size:1rem}.header-login-button{display:inline-flex;min-height:2.45rem;max-width:8.5rem;align-items:center;justify-content:center;overflow:hidden;border:1px solid rgba(231,199,119,.42);border-radius:999px;background:#fffdf9c7;padding:0 .86rem;color:#8f514b;font-size:.88rem;font-weight:700;text-overflow:ellipsis;white-space:nowrap;box-shadow:0 10px 26px #8f5b7514}.mobile-menu-button{display:none;min-height:2.6rem;border-radius:999px;background:#594550;padding:0 1rem;color:#fff9f2;font-size:.9rem}.mobile-nav-panel{display:none}.route-transition{animation:routeFade .26s ease both}.page-view{position:relative;min-height:100vh;padding-top:5.25rem}.page-section{padding:7rem clamp(1rem,4vw,3rem) 4.5rem}.home-page{isolation:isolate;display:flex;align-items:center;overflow:hidden;padding:6rem clamp(1.25rem,4vw,3rem) 2.5rem}.home-grid{display:grid;width:min(100%,1180px);margin:0 auto;align-items:center;gap:clamp(2rem,5vw,4rem);grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr)}.primary-cta,.soft-button{min-height:2.9rem;border-radius:999px;background:#594550;padding:0 1.45rem;color:#fff9f2;font-weight:600;box-shadow:0 14px 30px #8f5b7529;transition:transform .16s ease,background .16s ease}.primary-cta{margin-top:2rem}.primary-cta:hover,.soft-button:hover,.primary-cta:focus-visible,.soft-button:focus-visible{transform:translateY(-2px);background:#4e3c46;outline:none}button,a{-webkit-tap-highlight-color:transparent}.sparkle{position:absolute;color:#e7c777c7;font-size:clamp(1rem,2vw,1.5rem);line-height:1;text-shadow:0 0 18px rgba(255,255,255,.9)}.ribbon{position:absolute;z-index:-1;width:16rem;height:2.2rem;border-radius:999px;opacity:.28;filter:blur(.2px);animation:floatRibbon 7s ease-in-out infinite}.ribbon-one{left:-4rem;top:18%;background:linear-gradient(90deg,transparent,#f8c9d8,#e7c777,transparent)}.ribbon-two{bottom:14%;right:-5rem;background:linear-gradient(90deg,transparent,#d9c7f2,#f8c9d8,transparent);animation-delay:1.8s}.hero-photo-shell{aspect-ratio:4 / 3;border:10px solid rgba(255,255,255,.72);border-radius:36px;background:#ffffff6b;box-shadow:0 28px 70px #8f5b7533;padding:8px}.hero-title-glass{margin-top:-.25rem}.hero-title-glass .glass-surface__content{min-height:clamp(13.5rem,32vw,25rem);justify-content:center;padding:clamp(1.1rem,3.2vw,2rem)}.hero-title-glass h1{text-shadow:0 1px 18px rgba(255,255,255,.46)}.music-dot{width:.62rem;height:.62rem;border-radius:999px;background:#c8b1bd;box-shadow:0 0 0 5px #c8b1bd24}.music-dot.is-on{background:#e7c777;box-shadow:0 0 0 5px #e7c77733}.timeline-line{position:absolute;inset:1rem auto 1rem 50%;width:1px;background:linear-gradient(180deg,transparent,rgba(231,199,119,.55),transparent)}.memory-card{position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.74);border-radius:8px;background:#ffffff9e;box-shadow:0 18px 44px #8f5b7521;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.memory-card:before{position:absolute;top:1.15rem;right:1.15rem;width:.7rem;height:.7rem;border-radius:999px;background:#e7c777;box-shadow:0 0 0 7px #e7c77724;content:""}.memory-wall{-moz-column-count:5;column-count:5;-moz-column-gap:clamp(.72rem,1.4vw,1.2rem);column-gap:clamp(.72rem,1.4vw,1.2rem)}.memory-wall-tile{position:relative;display:inline-block;width:100%;margin:0 0 clamp(.72rem,1.4vw,1.2rem);-moz-column-break-inside:avoid;break-inside:avoid;transform:rotate(var(--rotate));overflow:hidden;border:8px solid rgba(255,253,249,.95);border-bottom-width:22px;border-radius:7px;background:#fffdf9;box-shadow:0 16px 34px #61495729;transition:transform .18s ease,box-shadow .18s ease,filter .18s ease}.memory-wall-tile:hover,.memory-wall-tile:focus-visible{transform:rotate(0) translateY(-4px);box-shadow:0 24px 48px #6149573b;filter:saturate(1.04);outline:none}.memory-wall-tile img{display:block;border-radius:3px;background:linear-gradient(135deg,#fce7ef,#f0e8ff)}.memory-wall-number{position:absolute;bottom:.28rem;left:.45rem;font-family:Georgia,Times New Roman,serif;font-size:.72rem;color:#59455094}.memory-wall-tile-1 img{aspect-ratio:4 / 5}.memory-wall-tile-2 img{aspect-ratio:1 / 1}.memory-wall-tile-3 img{aspect-ratio:5 / 4}.memory-wall-tile-4 img{aspect-ratio:3 / 4}.memory-wall-tile-5 img{aspect-ratio:4 / 3}.memory-wall-tile-6 img{aspect-ratio:1 / 1.18}.memory-wall-tile-7 img{aspect-ratio:5 / 6}.memory-wall-tile-8 img{aspect-ratio:6 / 5}.memory-wall-tile-9 img{aspect-ratio:4 / 4.7}.memory-modal-backdrop{position:fixed;inset:0;z-index:120;display:grid;align-items:center;justify-content:center;overflow-y:auto;background:#3628319e;padding:clamp(1rem,4vw,2.5rem);-webkit-backdrop-filter:blur(9px);backdrop-filter:blur(9px);animation:modalBackdropIn .18s ease both}.memory-modal-card{position:relative;display:grid;width:min(100%,960px);max-height:min(88vh,780px);grid-template-columns:minmax(0,1.08fr) minmax(280px,.92fr);overflow:hidden;border:1px solid rgba(255,255,255,.72);border-radius:8px;background:#fffdf9f5;box-shadow:0 30px 80px #402d384d;animation:memoryCardIn .22s cubic-bezier(.2,.85,.28,1) both}.memory-modal-close{position:absolute;right:.9rem;top:.9rem;z-index:2;min-height:2.55rem;border-radius:999px;background:#ffffffe6;padding:0 1.05rem;font-size:.9rem;color:#594550;box-shadow:0 10px 24px #61495724}.memory-modal-photo-wrap{position:relative;min-height:420px;background:linear-gradient(135deg,#fce7efbf,#f0e8ffcc)}.memory-modal-loading{position:absolute;inset:0;display:grid;place-items:center;color:#59455099}.memory-modal-photo{width:100%;height:100%;max-height:78vh;-o-object-fit:cover;object-fit:cover;opacity:0;transition:opacity .18s ease}.memory-modal-photo.is-ready{opacity:1}.memory-modal-copy{display:flex;min-height:420px;flex-direction:column;justify-content:center;padding:clamp(1.5rem,4vw,3rem)}.memory-modal-actions{position:absolute;bottom:1rem;right:1rem;display:flex;align-items:center;gap:.7rem;border-radius:999px;background:#ffffffe0;padding:.42rem;box-shadow:0 10px 24px #61495721}.memory-modal-actions button{min-height:2.35rem;border-radius:999px;background:#594550;padding:0 .9rem;font-size:.86rem;color:#fff9f2}.memory-modal-actions span{min-width:3.9rem;text-align:center;font-size:.82rem;color:#594550a8}.letter-paper{position:relative;overflow:hidden;border:1px solid rgba(231,199,119,.32);border-radius:8px;background:linear-gradient(#ffffffc7,#ffffffc7),repeating-linear-gradient(0deg,transparent 0,transparent 2.15rem,rgba(217,199,242,.28) 2.2rem);box-shadow:0 22px 60px #8f5b7529;padding:clamp(1.5rem,5vw,3.5rem)}.letter-stage{display:grid;width:min(100%,940px);margin:0 auto;gap:1.5rem}.letter-photo-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(.7rem,2vw,1.2rem)}.letter-photo-strip img{aspect-ratio:4 / 3;width:100%;transform:rotate(var(--tilt));border:8px solid rgba(255,253,249,.92);border-radius:7px;-o-object-fit:cover;object-fit:cover;box-shadow:0 14px 32px #8f5b7524}.games-progress-panel{display:flex;width:min(100%,920px);margin:0 auto 1.3rem;align-items:center;justify-content:space-between;gap:1rem;border:1px solid rgba(255,255,255,.72);border-radius:8px;background:#fffdf99e;padding:1rem 1.15rem;box-shadow:0 18px 44px #8f5b751a;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.games-progress-panel div{display:flex;align-items:baseline;gap:.8rem}.games-progress-panel span{color:#5945509e;font-size:.92rem}.games-progress-panel strong{color:#594550;font-size:1.45rem}.games-progress-panel p{color:#594550ad;font-size:.95rem}.game-card-grid{display:grid;width:min(100%,920px);margin:0 auto;gap:1rem;grid-template-columns:repeat(2,minmax(0,1fr))}.game-entry-card,.game-play-card,.locked-card,.hidden-letter-card,.special-media{border:1px solid rgba(255,255,255,.74);border-radius:8px;background:#fffdf9ad;box-shadow:0 18px 44px #8f5b7521;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.game-entry-card{position:relative;min-height:12rem;padding:1.2rem;text-align:left;transition:transform .17s ease,box-shadow .17s ease,background .17s ease}.game-entry-card:hover,.game-entry-card:focus-visible{transform:translateY(-3px);background:#fffdf9db;box-shadow:0 24px 52px #8f5b752e;outline:none}.game-entry-card h2,.game-play-head h2,.locked-card h1,.hidden-letter-card h2{margin-top:.45rem;font-family:Georgia,Times New Roman,serif;color:#594550;font-size:clamp(1.45rem,3vw,2rem)}.game-entry-card p:last-child{margin-top:.8rem;color:#594550a8;line-height:1.75}.game-kicker{color:#b99a49;font-size:.8rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase}.status-badge{display:inline-flex;min-height:2rem;align-items:center;border-radius:999px;background:#d9c7f252;padding:0 .75rem;color:#594550ad;font-size:.82rem}.status-badge.is-done{background:#e7c7773d;color:#8f732b}.game-entry-card .status-badge{position:absolute;right:1rem;top:1rem}.active-game-area{display:grid;width:min(100%,980px);margin:0 auto;gap:1rem}.game-play-card{padding:clamp(1rem,3vw,1.5rem)}.game-play-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.15rem}.game-active-caption,.game-help,.egg-line{margin-top:1rem;text-align:center;color:#594550a8}.match-grid{display:grid;gap:.75rem;grid-template-columns:repeat(4,minmax(0,1fr))}.match-card{position:relative;aspect-ratio:1 / 1.16;border-radius:8px;perspective:800px}.match-card-back,.match-card-front{position:absolute;inset:0;display:grid;place-items:center;overflow:hidden;border-radius:8px;backface-visibility:hidden;transition:transform .24s ease}.match-card-back{border:1px solid rgba(255,255,255,.72);background:linear-gradient(135deg,#f8c9d8eb,#d9c7f2c7),radial-gradient(circle at 30% 20%,rgba(255,255,255,.65),transparent 42%);color:#fff9f2;font-family:Georgia,Times New Roman,serif}.match-card-front{transform:rotateY(180deg);border:6px solid rgba(255,253,249,.92);background:#fffdf9}.match-card-front img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.match-card.is-open .match-card-back{transform:rotateY(180deg)}.match-card.is-open .match-card-front{transform:rotateY(360deg)}.soft-popover{margin-top:1.1rem;border:1px solid rgba(231,199,119,.35);border-radius:8px;background:#fffdf9d1;padding:1rem;text-align:center;box-shadow:0 12px 32px #8f5b751f}.soft-popover h3{font-family:Georgia,Times New Roman,serif;font-size:1.35rem;color:#594550}.soft-popover p{margin-top:.4rem;color:#594550ad;line-height:1.75}.soft-popover.is-inline{text-align:left}.quiz-intro{margin:-.2rem 0 1rem;color:#594550ad;line-height:1.8}.quiz-list{display:grid;gap:1rem}.quiz-card{border:1px solid rgba(255,255,255,.72);border-radius:8px;background:#fffdf994;padding:clamp(1rem,3vw,1.25rem)}.quiz-question-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.7rem;color:#b99a49;font-size:.86rem;font-weight:700}.quiz-card h3{font-family:Georgia,Times New Roman,serif;color:#594550;font-size:clamp(1.2rem,2.5vw,1.55rem);line-height:1.45}.quiz-result{border-radius:999px;background:#f8c9d857;padding:.25rem .62rem;color:#9d5c76;font-size:.78rem}.quiz-result.is-correct{background:#e7c77738;color:#8f732b}.quiz-options{display:grid;gap:.65rem;margin-top:.95rem;grid-template-columns:repeat(2,minmax(0,1fr))}.quiz-option{min-height:3.2rem;border:1px solid rgba(255,255,255,.74);border-radius:8px;background:#ffffff8f;padding:.75rem .9rem;color:#594550c7;line-height:1.45;text-align:left;transition:transform .15s ease,border-color .15s ease,background .15s ease}.quiz-option:hover,.quiz-option:focus-visible{transform:translateY(-1px);border-color:#e7c7777a;background:#fffdf9e6;outline:none}.quiz-option.is-selected{border-color:#d9c7f2e6;background:#f0e8ff8f}.quiz-option.is-correct{border-color:#e7c777c7;background:#e7c7772e}.quiz-option.is-wrong{border-color:#f8c9d8e6;background:#f8c9d840}.quiz-feedback{margin-top:.85rem;border-radius:8px;background:#f8c9d82e;padding:.75rem .85rem;color:#594550b3;line-height:1.75}.quiz-feedback.is-correct{background:#e7c77729}.quiz-complete h3{font-size:clamp(1.35rem,3vw,1.75rem)}.letter-paper:before{position:absolute;inset:0 auto 0 1.35rem;width:1px;background:#f8c9d8d9;content:""}.gift-box{position:relative;width:min(48vw,190px);height:min(48vw,190px);margin-inline:auto;border:0;background:transparent;cursor:pointer}.gift-body,.gift-lid,.gift-bow{position:absolute;left:50%;transform:translate(-50%);display:block}.gift-body{bottom:14%;width:72%;height:54%;border-radius:8px;background:linear-gradient(90deg,transparent 44%,rgba(255,255,255,.44) 44%,rgba(255,255,255,.44) 56%,transparent 56%),linear-gradient(135deg,#f8c9d8,#d9c7f2);box-shadow:0 18px 38px #8f5b752e}.gift-lid{bottom:66%;width:82%;height:22%;border-radius:8px;background:linear-gradient(90deg,transparent 45%,rgba(255,255,255,.45) 45%,rgba(255,255,255,.45) 55%,transparent 55%),linear-gradient(135deg,#e7c777,#f8c9d8);transform-origin:10% 100%;transition:transform .22s ease}.gift-bow{bottom:82%;width:48%;height:24%}.gift-bow:before,.gift-bow:after{position:absolute;top:0;width:48%;height:100%;border:8px solid #e7c777;border-radius:999px 999px 999px 4px;content:""}.gift-bow:before{left:0;transform:rotate(-28deg)}.gift-bow:after{right:0;transform:scaleX(-1) rotate(-28deg)}.gift-box:hover .gift-lid,.gift-box:focus-visible .gift-lid,.gift-box.is-opened .gift-lid{transform:translate(-55%) translateY(-18px) rotate(-10deg)}.gift-box:focus-visible{outline:2px solid rgba(231,199,119,.65);outline-offset:6px;border-radius:14px}.puzzle-layout{display:grid;align-items:center;gap:1.2rem;grid-template-columns:minmax(260px,.9fr) minmax(240px,1fr)}.puzzle-board{display:grid;aspect-ratio:1;width:min(100%,430px);margin:0 auto;gap:.22rem;grid-template-columns:repeat(3,1fr);border:8px solid rgba(255,253,249,.9);border-radius:8px;background:#fffdf980;box-shadow:0 18px 44px #8f5b7524}.puzzle-piece{min-height:0;border-radius:5px;background-size:300% 300%;box-shadow:inset 0 0 0 1px #ffffff8c;transition:transform .15s ease,box-shadow .15s ease}.puzzle-piece.is-selected{transform:scale(.96);box-shadow:inset 0 0 0 3px #e7c777d1,0 10px 22px #8f5b7526}.puzzle-board.is-solved .puzzle-piece{box-shadow:none}.puzzle-copy{color:#594550ad;line-height:1.85}.puzzle-copy img{aspect-ratio:4 / 3;width:min(100%,320px);margin-bottom:1rem;border:8px solid rgba(255,253,249,.94);border-radius:8px;-o-object-fit:cover;object-fit:cover;box-shadow:0 16px 36px #8f5b7521}.star-score-row{display:flex;flex-wrap:wrap;gap:.65rem;margin-bottom:.85rem}.star-score-row span{border-radius:999px;background:#fffdf9bd;padding:.42rem .75rem;color:#594550ad;font-size:.9rem}.star-stage{position:relative;height:min(58vh,420px);min-height:300px;overflow:hidden;border:1px solid rgba(255,255,255,.68);border-radius:8px;background:radial-gradient(circle at 20% 16%,rgba(255,255,255,.76),transparent 10rem),linear-gradient(135deg,#fce7efd1,#f0e8ffd1)}.star-stage-empty{display:grid;height:100%;place-items:center;align-content:center;gap:1rem;color:#594550ad;text-align:center}.falling-star{position:absolute;top:-2rem;border-radius:999px;background:radial-gradient(circle,#fffdf9 0 22%,#e7c777 24% 54%,#e7c7772e 56%);box-shadow:0 0 22px #e7c77773;animation:fallSoft linear forwards}.egg-line{font-family:Georgia,Times New Roman,serif;font-size:1.15rem;color:#8f732b}.scratch-card{position:relative;display:grid;height:min(52vh,340px);min-height:250px;place-items:center;overflow:hidden;border:1px solid rgba(255,255,255,.68);border-radius:8px;background:radial-gradient(circle at 20% 20%,rgba(255,255,255,.72),transparent 10rem),linear-gradient(135deg,#fce7ef,#f0e8ff)}.scratch-message{width:min(82%,560px);border:1px solid rgba(231,199,119,.35);border-radius:8px;background:#fffdf9b8;padding:1.25rem;text-align:center;box-shadow:0 16px 36px #8f5b751f}.scratch-message p{font-family:Georgia,Times New Roman,serif;font-size:clamp(1.5rem,5vw,2.4rem);line-height:1.35;color:#594550}.scratch-canvas{position:absolute;inset:0;width:100%;height:100%;cursor:grab;touch-action:none}.finale-locked,.finale-page{display:grid;place-items:center;overflow:hidden}.locked-card{position:relative;width:min(100%,640px);padding:clamp(1.5rem,5vw,2.4rem);text-align:center}.locked-card p{margin:1rem auto;max-width:30rem;color:#594550ad;line-height:1.8}.finale-grid{display:grid;align-items:stretch;gap:1rem;margin-top:2rem;grid-template-columns:minmax(0,1fr) minmax(0,1fr);text-align:left}.hidden-letter-card,.special-media{overflow:hidden;padding:1.25rem}.hidden-letter-card p{margin-top:.9rem;color:#594550b3;line-height:1.9}.special-media{position:relative;min-height:260px;padding:0}.special-media img{width:100%;height:100%;min-height:260px;-o-object-fit:cover;object-fit:cover}.special-media span{position:absolute;left:1rem;bottom:1rem;border-radius:999px;background:#fffdf9d1;padding:.5rem .9rem;color:#594550ad;font-size:.86rem}body{background:radial-gradient(circle at 18% 18%,rgba(255,226,151,.28),transparent 18rem),radial-gradient(circle at 85% 8%,rgba(154,207,255,.3),transparent 24rem),linear-gradient(180deg,#fff6e9,#ffe9e8 42%,#f2e8ff)}.site-header{background:#fff6e9c2;border-bottom:2px solid rgba(146,93,76,.08)}.site-header.is-scrolled{background:#fff6e9e6;box-shadow:0 10px 26px #7953481f}.site-brand{color:#a64f5c;font-family:Comic Sans MS,Segoe Print,Georgia,serif;font-weight:700;letter-spacing:.02em}.desktop-nav{border-color:#ffffffb8;background:#fff8ecb8;box-shadow:0 8px 22px #79534814}.nav-link{color:#6a564e;font-weight:700}.nav-link:hover,.nav-link:focus-visible,.nav-link.is-active{background:#ffe6ed;color:#c44f66;box-shadow:inset 0 -3px #e771854d}.music-toggle,.progress-pill{border-color:#d2905d40;background:#fff8ecd1;color:#8f514b}.section-title{position:relative;z-index:1;width:-moz-fit-content;width:fit-content;min-width:min(100%,360px);padding:.2rem 1.2rem .8rem}.section-title:before{position:absolute;inset:1.4rem 0 0;z-index:-1;border:2px solid rgba(151,91,65,.2);border-radius:18px 18px 28px 28px;background:linear-gradient(180deg,#fff4dcf5,#ffe8cfeb),repeating-linear-gradient(90deg,rgba(151,91,65,.05) 0 12px,transparent 12px 24px);box-shadow:0 14px 34px #7953481f,inset 0 0 0 3px #ffffff5c;content:""}.section-eyebrow{color:#d49745}.section-heading{color:#a64f5c;font-family:Comic Sans MS,Segoe Print,Georgia,serif;font-weight:700}.section-subtitle{color:#5b4740b8}.birthday-town-home{background:linear-gradient(180deg,#79bef66b,#fff6e92e 50%,#ffe7d847),radial-gradient(circle at 84% 22%,rgba(255,255,255,.95) 0 2.3rem,transparent 2.4rem),radial-gradient(circle at 88% 18%,rgba(255,255,255,.92) 0 1.7rem,transparent 1.8rem)}.birthday-town-home .home-grid{position:relative;overflow:hidden;min-height:min(720px,calc(100vh - 8rem));border:10px solid rgba(255,248,236,.82);border-radius:30px;background:radial-gradient(circle at 14% 18%,rgba(255,255,255,.9) 0 2.2rem,transparent 2.3rem),radial-gradient(circle at 20% 14%,rgba(255,255,255,.86) 0 1.5rem,transparent 1.6rem),linear-gradient(180deg,#83c8ff,#bde6ff 38%,#ffe5d8 39%,#fff5df);box-shadow:0 24px 70px #7953482e,inset 0 0 0 2px #ffffff57;padding:clamp(1rem,4vw,3rem)}.birthday-town-home .home-grid:before{position:absolute;left:-4%;right:-4%;bottom:-1px;height:28%;background:radial-gradient(circle at 10% 84%,#f6b7c5 0 .45rem,transparent .5rem),radial-gradient(circle at 18% 72%,#f6da73 0 .42rem,transparent .47rem),radial-gradient(circle at 84% 78%,#f6b7c5 0 .5rem,transparent .55rem),radial-gradient(circle at 76% 68%,#d7bbf2 0 .45rem,transparent .5rem),linear-gradient(180deg,#a7d68b,#80c475);border-radius:50% 50% 0 0/42% 42% 0 0;content:""}.birthday-town-home .home-grid:after{position:absolute;left:8%;bottom:19%;width:13rem;height:9rem;border:3px solid rgba(142,84,72,.18);border-radius:18px 18px 12px 12px;background:linear-gradient(135deg,transparent 0 50%,rgba(169,82,93,.25) 50% 52%,transparent 52%) top / 100% 42% no-repeat,linear-gradient(180deg,#ffd4d8 0 42%,#ffe6cb 42%);box-shadow:0 14px 30px #79534824;opacity:.72;content:""}.birthday-town-home .home-grid>*{position:relative;z-index:1}.hero-title-glass.glass-surface--fallback{border:3px solid rgba(151,91,65,.16);background:linear-gradient(180deg,#fff4dceb,#ffe2d9d6),repeating-linear-gradient(90deg,rgba(151,91,65,.04) 0 16px,transparent 16px 32px);box-shadow:0 18px 44px #79534824,inset 0 0 0 4px #ffffff47;transform:rotate(-1deg)}.hero-title-glass h1{color:#c4566c;font-family:Comic Sans MS,Segoe Print,Georgia,serif;text-shadow:0 3px 0 rgba(255,255,255,.55)}.birthday-pressure-title{display:grid;width:min(100%,560px);min-height:clamp(12.5rem,26vw,19rem);align-items:center;margin-inline:auto}.birthday-pressure-text{display:block;width:100%;margin:0;color:#c4566c;font-family:Comic Sans MS,Segoe Print,Microsoft YaHei,sans-serif;font-size:clamp(2.55rem,7vw,5.15rem);font-weight:900;line-height:1.13;letter-spacing:.02em;text-align:center;-webkit-user-select:none;-moz-user-select:none;user-select:none}.birthday-pressure-text span{display:inline-block;color:#c4566c;text-shadow:0 3px 0 rgba(255,255,255,.55),0 14px 24px rgba(196,86,108,.14);transform-origin:center bottom;transition:color .18s ease,transform .18s ease,text-shadow .18s ease}.birthday-pressure-text:hover span{transform:translateY(-.08em) scaleY(1.08);text-shadow:0 3px 0 rgba(255,255,255,.65),0 18px 32px rgba(196,86,108,.26)}.birthday-pressure-text span:hover{color:#a64f5c;transform:translateY(-.18em) scale(.96,1.22);transform-origin:center bottom;text-shadow:0 4px 0 rgba(255,255,255,.74),0 26px 38px rgba(196,86,108,.34)}.primary-cta{border:3px solid rgba(255,255,255,.72);background:linear-gradient(180deg,#ee7b8f,#d95f75);box-shadow:0 14px #9c475326,0 20px 36px #9c475338}.primary-cta:before{content:"礼物";margin-right:.55rem;font-size:.8rem;opacity:.85}.birthday-profile-card .pc-card{border-color:#fff5e3eb;box-shadow:0 24px #7d504214,0 30px 70px #7953483d}.memories-town-page{position:relative;min-height:100vh;background:linear-gradient(180deg,#a9d3ff8c,#fff6e9b8),repeating-linear-gradient(0deg,transparent 0 28px,rgba(255,255,255,.18) 29px 30px)}.memories-town-page:before,.memories-town-page:after{position:absolute;left:5%;right:5%;z-index:0;height:2px;background:#835b4c33;content:""}.memories-town-page:before{top:8.8rem;transform:rotate(-1.5deg)}.memories-town-page:after{top:13rem;transform:rotate(1.2deg)}.memories-town-page>*{position:relative;z-index:1}.memory-wall-tile{border-color:#fff8ecfa;border-bottom-width:26px;box-shadow:0 14px #7953480d,0 20px 34px #61495729}.memory-wall-tile:before{position:absolute;top:-.45rem;left:50%;z-index:2;width:1.7rem;height:.85rem;transform:translate(-50%) rotate(-3deg);border-radius:5px;background:#e7c777cc;box-shadow:0 2px 5px #79534824;content:""}.memory-modal-card{border:8px solid rgba(255,248,236,.94);border-radius:24px;background:#fff8ef}.memory-modal-close{background:#e86f80;color:#fff8ef}.games-town-page{background:radial-gradient(circle at 82% 16%,rgba(255,255,255,.8) 0 2.1rem,transparent 2.2rem),linear-gradient(180deg,#b9e3ff,#fff3de 45%,#ffe7ee)}.games-progress-panel{border:3px solid rgba(255,248,236,.82);border-radius:20px;background:#fff8ecc7}.game-card-grid{position:relative;padding-top:1.8rem}.game-entry-card{overflow:visible;min-height:15rem;border:4px solid rgba(255,248,236,.86);border-radius:18px;background:linear-gradient(180deg,#fff8ecf0,#ffe4e0d6);padding-top:4.2rem}.game-entry-card:before{position:absolute;left:9%;right:9%;top:-1.4rem;height:4.6rem;clip-path:polygon(50% 0,100% 60%,88% 100%,12% 100%,0 60%);background:linear-gradient(135deg,#f19bad,#d9c7f2);border-radius:18px 18px 10px 10px;box-shadow:0 10px 20px #7953481f;content:""}.game-entry-card:after{position:absolute;right:1.25rem;bottom:1.1rem;width:3.5rem;height:3.5rem;border:3px solid rgba(151,91,65,.13);border-radius:14px 14px 6px 6px;background:linear-gradient(90deg,transparent 45%,rgba(151,91,65,.14) 46% 54%,transparent 55%),linear-gradient(180deg,transparent 45%,rgba(151,91,65,.14) 46% 54%,transparent 55%),#ffe8a9;content:""}.game-entry-card:nth-child(2):before{background:linear-gradient(135deg,#f2c36b,#d9c7f2)}.game-entry-card:nth-child(3):before{background:linear-gradient(135deg,#d9c7f2,#9bcdf8)}.game-entry-card:nth-child(4):before{background:linear-gradient(135deg,#f7a9bd,#f2c36b)}.game-entry-card h2{color:#a64f5c}.status-badge{border:1px solid rgba(151,91,65,.08);background:#fff6e9}.active-game-area .game-play-card,.quiz-card,.scratch-card,.puzzle-board{border-color:#fff8eceb}.letter-town-page{background:radial-gradient(circle at 18% 20%,rgba(248,201,216,.38),transparent 20rem),linear-gradient(180deg,#fff8ef,#ffeef2)}.letter-paper{border:5px solid rgba(255,248,236,.9);border-radius:22px;background:linear-gradient(#fffbf2d1,#fffbf2d1),repeating-linear-gradient(0deg,transparent 0,transparent 2.15rem,rgba(217,199,242,.28) 2.2rem)}.finale-town-page{background:radial-gradient(circle at 18% 22%,rgba(255,231,119,.35) 0 .2rem,transparent .24rem),radial-gradient(circle at 70% 18%,rgba(255,231,119,.28) 0 .18rem,transparent .22rem),radial-gradient(circle at 82% 44%,rgba(255,231,119,.34) 0 .2rem,transparent .24rem),linear-gradient(180deg,#243a78,#415a99 45%,#ffe5c8)}.finale-page .section-heading,.finale-page h1,.finale-page .game-kicker,.finale-page p{color:#fff8ef;text-shadow:0 2px 18px rgba(29,39,82,.45)}.locked-card,.hidden-letter-card,.special-media{border:4px solid rgba(255,248,236,.82);border-radius:22px;background:#fff8ecd1}.finale-page .gift-box{filter:drop-shadow(0 0 28px rgba(255,218,120,.48))}.games-town-page{padding:4.65rem 0 0;background:#c9eaff}.game-town-map{position:relative;isolation:isolate;min-height:calc(100vh - 4.65rem);overflow:hidden;padding:clamp(1rem,3vw,1.6rem);background:radial-gradient(circle at 8% 28%,rgba(255,255,255,.86) 0 1.2rem,transparent 1.25rem),radial-gradient(circle at 13% 24%,rgba(255,255,255,.86) 0 1.8rem,transparent 1.85rem),radial-gradient(circle at 19% 27%,rgba(255,255,255,.86) 0 1.1rem,transparent 1.15rem),radial-gradient(circle at 84% 20%,rgba(255,255,255,.9) 0 1.3rem,transparent 1.35rem),radial-gradient(circle at 89% 17%,rgba(255,255,255,.88) 0 1.9rem,transparent 1.95rem),linear-gradient(180deg,#93d3ff,#c9ebff 38%,#d8edb2 38.5%,#9dd784)}.game-town-map:before{position:absolute;left:-8%;right:-8%;bottom:-12%;z-index:-1;height:42%;border-radius:50% 50% 0 0/35% 35% 0 0;background:radial-gradient(circle at 10% 48%,#ffd36a 0 .36rem,transparent .42rem),radial-gradient(circle at 16% 38%,#f48aa1 0 .38rem,transparent .44rem),radial-gradient(circle at 28% 60%,#fff0a2 0 .34rem,transparent .4rem),radial-gradient(circle at 76% 52%,#f48aa1 0 .42rem,transparent .48rem),radial-gradient(circle at 84% 38%,#fff0a2 0 .36rem,transparent .42rem),linear-gradient(180deg,#a7da79,#75bd68);content:""}.game-town-map:after{position:absolute;inset:auto 0 0;z-index:-1;height:22%;background:radial-gradient(circle at 8% 65%,#f8b1bf 0 .35rem,transparent .42rem),radial-gradient(circle at 22% 78%,#f8db72 0 .35rem,transparent .42rem),radial-gradient(circle at 68% 72%,#f8b1bf 0 .42rem,transparent .5rem),radial-gradient(circle at 88% 62%,#f8db72 0 .36rem,transparent .43rem);content:""}.game-town-map .section-title{display:block;margin-bottom:1rem}.game-town-map .section-title:before{inset:1.2rem -1.8rem -.15rem;border-radius:18px 18px 28px 28px;transform:rotate(-.6deg)}.game-town-map .section-heading{font-size:clamp(2.1rem,5vw,3rem)}.game-town-houses{position:relative;width:min(100%,980px);min-height:clamp(520px,64vh,650px);margin:0 auto}.map-path{position:absolute;z-index:0;background:#ffecc6e0;box-shadow:inset 0 0 0 4px #ffffff52}.path-main{left:50%;bottom:0;width:8rem;height:58%;transform:translate(-50%);clip-path:polygon(38% 0,62% 0,92% 100%,8% 100%)}.path-left{left:20%;bottom:24%;width:34%;height:4.5rem;transform:rotate(-18deg);border-radius:999px}.path-right{right:18%;bottom:28%;width:34%;height:4.5rem;transform:rotate(18deg);border-radius:999px}.map-cloud{position:absolute;z-index:0;width:7.5rem;height:2.8rem;border-radius:999px;background:#ffffffe0;box-shadow:1.8rem -.9rem 0 .25rem #ffffffe0,3.8rem -.2rem 0 .1rem #ffffffe0}.cloud-one{left:6%;top:17%}.cloud-two{right:8%;top:18%;transform:scale(.78)}.map-balloon{position:absolute;z-index:1;width:2.3rem;height:3rem;border-radius:999px/64% 64% 42% 42%;background:#f5869d;box-shadow:inset -.35rem -.45rem #ad4c5b1f,0 .2rem #ffffff52 inset}.map-balloon:after{position:absolute;left:50%;top:100%;width:1px;height:3.6rem;background:#745b4657;content:""}.balloon-one{left:8%;top:25%}.balloon-two{left:12%;top:20%;transform:scale(.78);background:#8fc7f6}.map-wheel{position:absolute;right:11%;top:24%;z-index:0;width:min(18vw,11rem);aspect-ratio:1;border:5px solid rgba(150,109,90,.28);border-radius:999px;opacity:.82}.map-wheel:before,.map-wheel:after{position:absolute;inset:50% auto auto 50%;width:100%;height:4px;transform:translate(-50%,-50%);background:#966d5a38;content:""}.map-wheel:after{transform:translate(-50%,-50%) rotate(90deg)}.game-house{position:absolute;z-index:2;width:clamp(12rem,21vw,15.8rem);height:clamp(11rem,20vw,14.5rem);border:0;background:transparent;color:#624d43;cursor:pointer;transition:transform .18s ease,filter .18s ease}.game-house:hover,.game-house:focus-visible{transform:translateY(-8px) rotate(0);filter:saturate(1.05);outline:none}.house-quiz{left:13%;top:13%;transform:rotate(-2deg)}.house-puzzle{right:13%;top:14%;transform:rotate(1.6deg)}.house-memory{left:22%;bottom:8%;transform:rotate(1.5deg)}.house-scratch{right:22%;bottom:8%;transform:rotate(-1.4deg)}.house-roof{position:absolute;left:12%;right:12%;top:0;height:42%;clip-path:polygon(50% 0,100% 65%,88% 100%,12% 100%,0 65%);border-radius:22px 22px 10px 10px;background:linear-gradient(135deg,#f39bae,#cfa9f2);box-shadow:0 12px 20px #744d411f}.house-puzzle .house-roof{background:linear-gradient(135deg,#f2c26b,#88b9f4)}.house-memory .house-roof{background:linear-gradient(135deg,#d7b7ff,#8fc7f6)}.house-scratch .house-roof{background:linear-gradient(135deg,#f8a49a,#f2c26b)}.house-body{position:absolute;inset:33% 18% 18%;display:grid;place-items:center;border:4px solid rgba(255,246,226,.8);border-radius:18px 18px 12px 12px;background:linear-gradient(90deg,transparent 47%,rgba(145,91,72,.12) 48% 52%,transparent 53%),linear-gradient(180deg,#ffe2be,#ffcfd8);box-shadow:inset 0 0 0 2px #ffffff47,0 18px 28px #744d4126}.house-window{display:grid;min-width:4.2rem;min-height:3.2rem;place-items:center;border:3px solid rgba(139,89,70,.16);border-radius:12px 12px 6px 6px;background:linear-gradient(90deg,transparent 47%,rgba(139,89,70,.12) 48% 52%,transparent 53%),linear-gradient(180deg,transparent 47%,rgba(139,89,70,.12) 48% 52%,transparent 53%),#fff4b8;color:#a64f5c;font-size:.82rem;font-weight:800}.house-sign{position:absolute;left:7%;right:7%;bottom:0;display:grid;gap:.15rem;min-height:3.4rem;align-content:center;border:3px solid rgba(150,91,66,.18);border-radius:10px;background:#fff6e2eb;box-shadow:0 8px 16px #744d411f,inset 0 0 0 2px #ffffff52}.house-sign strong{color:#9d5160;font-family:Comic Sans MS,Segoe Print,Georgia,serif;font-size:clamp(1rem,2vw,1.16rem);line-height:1.1}.house-sign small{justify-self:center;border-radius:999px;background:#f8c9d86b;padding:.12rem .65rem;color:#a64f5c;font-size:.78rem}.game-house:has(.house-sign small){text-align:center}.map-progress-sign{position:absolute;right:clamp(1rem,5vw,4rem);bottom:clamp(1rem,5vh,3.5rem);z-index:3;display:grid;min-width:8.5rem;justify-items:center;gap:.25rem;border:4px solid rgba(151,91,65,.18);border-radius:8px;background:linear-gradient(180deg,#fff6e2f5,#ffe5c9f0),repeating-linear-gradient(90deg,rgba(151,91,65,.04) 0 12px,transparent 12px 24px);padding:.7rem 1rem;box-shadow:0 14px 24px #744d4129}.map-progress-sign span,.map-progress-sign p{color:#624d43b8;font-size:.82rem}.map-progress-sign strong{color:#5d464f;font-size:1.8rem;line-height:1}.back-to-town{justify-self:start;background:#e57977}.burst-piece{position:absolute;left:50%;top:10%;width:.55rem;height:.55rem;border-radius:999px;animation:burst 1.4s ease-out forwards}@media(max-width:767px){.site-header{padding:.58rem .72rem}.site-header-inner{grid-template-columns:minmax(0,1fr) auto;gap:.65rem}.site-brand{overflow:hidden;max-width:48vw;white-space:nowrap;text-overflow:ellipsis}.desktop-nav{display:none}.header-actions{gap:.38rem}.music-toggle.is-compact{min-width:3rem;padding:0 .58rem}.music-toggle.is-compact span:nth-child(2){display:none}.progress-pill{min-height:2.38rem;padding:0 .62rem;font-size:.82rem}.header-login-button{display:none}.mobile-menu-button{display:inline-flex;align-items:center}.mobile-nav-panel{display:grid;gap:.45rem;max-width:1180px;margin:.55rem auto 0;border:1px solid rgba(255,255,255,.72);border-radius:8px;background:#fffdf9e6;padding:.6rem;box-shadow:0 18px 44px #8f5b7529;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.mobile-nav-link{display:flex;min-height:2.8rem;align-items:center;justify-content:space-between;border-radius:8px;background:#f8c9d829;padding:0 .85rem;color:#594550;text-align:left}.mobile-nav-link.is-locked{color:#59455070}.mobile-progress{padding:.4rem .85rem .1rem;color:#59455099;font-size:.88rem}.page-view{padding-top:4.65rem}.page-section{padding:6.2rem 1rem 3.5rem}.home-page{padding:5.8rem 1rem 2rem}.home-grid{grid-template-columns:1fr}.hero-photo-shell{border-width:7px;border-radius:28px;padding:6px}.memory-card{border-radius:8px}.memory-wall{-moz-column-count:2;column-count:2}.memory-wall-tile{transform:none;border-width:6px;border-bottom-width:18px}.memory-modal-card{display:block;width:min(100%,420px);max-height:calc(100vh - 2rem);overflow-y:auto}.memory-modal-photo-wrap{min-height:0}.memory-modal-photo{aspect-ratio:4 / 5;max-height:58vh}.memory-modal-copy{min-height:0;padding:1.35rem 1.25rem 5.1rem}.memory-modal-actions{bottom:.85rem;left:.85rem;right:.85rem;justify-content:space-between}.letter-photo-strip{grid-template-columns:1fr 1fr}.letter-photo-strip img:last-child{display:none}.games-progress-panel{display:grid}.game-card-grid,.puzzle-layout,.finale-grid{grid-template-columns:1fr}.game-entry-card{min-height:11rem}.match-grid{gap:.5rem;grid-template-columns:repeat(4,minmax(0,1fr))}.match-card-back{font-size:.72rem}.puzzle-board{width:min(100%,330px)}.star-stage{min-height:330px}.scratch-card{min-height:310px}.quiz-options{grid-template-columns:1fr}.quiz-option{min-height:3.65rem;padding:.9rem 1rem;font-size:.96rem}}@media(min-width:640px)and (max-width:1023px){.memory-wall{-moz-column-count:3;column-count:3}}@media(min-width:1024px)and (max-width:1279px){.memory-wall{-moz-column-count:4;column-count:4}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}@keyframes routeFade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fallSoft{0%{transform:translateY(-2rem) rotate(0);opacity:0}10%{opacity:1}to{transform:translateY(28rem) rotate(180deg);opacity:.2}}@media(max-width:767px){.birthday-town-home .home-grid{min-height:auto;border-width:7px;border-radius:24px;padding:1rem}.birthday-town-home .home-grid:after{display:none}.section-title{min-width:min(100%,300px);padding-inline:.75rem}.game-entry-card{min-height:13.5rem}.game-entry-card:before{left:12%;right:12%;height:4rem}.games-town-page{padding-top:4.2rem}.game-town-map{min-height:calc(100vh - 4.2rem);padding:1rem .8rem 7.5rem}.game-town-map .section-title{margin-bottom:.4rem}.game-town-map .section-heading{font-size:2rem}.game-town-houses{display:grid;min-height:0;gap:1.2rem .7rem;grid-template-columns:repeat(2,minmax(0,1fr));padding-top:2rem}.game-house{position:relative;inset:auto;width:100%;height:11.5rem;transform:none}.house-body{left:15%;right:15%}.house-sign{left:3%;right:3%}.house-sign strong{font-size:.95rem}.map-progress-sign{left:50%;right:auto;bottom:1rem;transform:translate(-50%)}.map-wheel{right:-1.5rem;top:11rem;width:7rem}.path-main,.path-left,.path-right{opacity:.55}}.games-town-page{min-height:100vh;overflow:hidden;padding-top:4.65rem;background:#bee6ff}.games-town-page.is-playing{overflow:auto;padding-top:7rem;background:radial-gradient(circle at 82% 16%,rgba(255,255,255,.8) 0 2.1rem,transparent 2.2rem),linear-gradient(180deg,#b9e3ff,#fff3de 45%,#ffe7ee)}.friendship-town-map{position:relative;isolation:isolate;width:100%;min-height:calc(100vh - 4.65rem);overflow:hidden;padding:clamp(.75rem,2vw,1.25rem);background:radial-gradient(circle at 6% 28%,rgba(255,255,255,.9) 0 1.15rem,transparent 1.22rem),radial-gradient(circle at 12% 24%,rgba(255,255,255,.9) 0 1.75rem,transparent 1.84rem),radial-gradient(circle at 19% 27%,rgba(255,255,255,.9) 0 1rem,transparent 1.08rem),radial-gradient(circle at 83% 18%,rgba(255,255,255,.92) 0 1.28rem,transparent 1.36rem),radial-gradient(circle at 90% 16%,rgba(255,255,255,.9) 0 1.8rem,transparent 1.9rem),linear-gradient(180deg,#8fd0ff,#c8ecff 37%,#dcefb7 37.4%,#91cf76)}.friendship-town-map:before{position:absolute;left:-10%;right:-10%;bottom:-13%;z-index:-2;height:42%;border-radius:50% 50% 0 0/34% 34% 0 0;background:radial-gradient(circle at 9% 52%,#ffd368 0 .35rem,transparent .43rem),radial-gradient(circle at 14% 41%,#f58fa5 0 .38rem,transparent .46rem),radial-gradient(circle at 23% 62%,#fff0a0 0 .34rem,transparent .42rem),radial-gradient(circle at 72% 50%,#f58fa5 0 .42rem,transparent .5rem),radial-gradient(circle at 84% 38%,#fff0a0 0 .36rem,transparent .44rem),linear-gradient(180deg,#a9db7a,#76bd67);content:""}.friendship-town-map:after{position:absolute;inset:auto 0 0;z-index:-1;height:24%;background:radial-gradient(circle at 8% 65%,#f8b1bf 0 .35rem,transparent .43rem),radial-gradient(circle at 22% 78%,#f8db72 0 .35rem,transparent .43rem),radial-gradient(circle at 68% 72%,#f8b1bf 0 .42rem,transparent .5rem),radial-gradient(circle at 88% 62%,#f8db72 0 .36rem,transparent .44rem);content:""}.town-map-banner{position:relative;z-index:3;width:min(92vw,410px);margin:.25rem auto 0;border:3px solid rgba(150,91,66,.18);border-radius:19px 19px 27px 27px;background:linear-gradient(180deg,#fff5e0f7,#ffe2ccf0),repeating-linear-gradient(90deg,rgba(150,91,66,.05) 0 16px,transparent 16px 32px);padding:.72rem 1.2rem .9rem;text-align:center;box-shadow:0 16px 34px #754e3d1f,inset 0 0 0 3px #ffffff59}.town-map-banner:before,.town-map-banner:after{position:absolute;top:36%;width:3.6rem;height:1.65rem;background:#f6c398;content:""}.town-map-banner:before{left:-2.45rem;clip-path:polygon(0 0,100% 0,78% 50%,100% 100%,0 100%,18% 50%)}.town-map-banner:after{right:-2.45rem;clip-path:polygon(0 0,100% 0,82% 50%,100% 100%,0 100%,22% 50%)}.banner-pin{position:absolute;top:.72rem;width:.52rem;height:.52rem;border-radius:999px;background:#e6a64c;box-shadow:0 0 0 .28rem #e6a64c2e}.banner-pin.left{left:1.05rem}.banner-pin.right{right:1.05rem}.town-map-banner p{margin:0;color:#d59542;font-size:.75rem;font-weight:800;letter-spacing:.18em}.town-map-banner h1{margin:.05rem 0 .25rem;color:#9f5261;font-family:Comic Sans MS,Segoe Print,Georgia,serif;font-size:clamp(2.1rem,4.4vw,3.1rem);font-weight:800;line-height:1}.town-map-banner span:not(.banner-pin){display:block;color:#594550b3;font-size:clamp(.82rem,1.5vw,.98rem)}.town-cloud{position:absolute;z-index:1;width:7.2rem;height:2.6rem;border-radius:999px;background:#ffffffe0;animation:cloudDrift 8s ease-in-out infinite}.town-cloud:before,.town-cloud:after{position:absolute;bottom:.35rem;border-radius:999px;background:inherit;content:""}.town-cloud:before{left:1.2rem;width:2.6rem;height:2.6rem}.town-cloud:after{right:1.2rem;width:2rem;height:2rem}.cloud-a{left:5%;top:19%}.cloud-b{right:8%;top:17%;transform:scale(.82);animation-delay:1.2s}.town-balloon{position:absolute;z-index:2;width:2.2rem;height:3rem;border-radius:999px/64% 64% 42% 42%;background:#f5869d;box-shadow:inset -.35rem -.45rem #ad4c5b1f,0 .2rem #ffffff52 inset}.town-balloon:after{position:absolute;left:50%;top:100%;width:1px;height:3.4rem;background:#745b4657;content:""}.balloon-a{left:7%;top:30%}.balloon-b{left:11%;top:25%;transform:scale(.76);background:#8fc7f6}.town-ferris-wheel{position:absolute;right:9%;top:25%;z-index:1;width:min(18vw,10.8rem);aspect-ratio:1;border:5px solid rgba(150,109,90,.28);border-radius:999px;opacity:.78}.town-ferris-wheel:before,.town-ferris-wheel:after{position:absolute;inset:50% auto auto 50%;width:100%;height:4px;transform:translate(-50%,-50%);background:#966d5a38;content:""}.town-ferris-wheel:after{transform:translate(-50%,-50%) rotate(90deg)}.path{position:absolute;z-index:0;background:#ffecc6e0;box-shadow:inset 0 0 0 4px #ffffff57}.path-center{left:50%;bottom:-2%;width:8.4rem;height:58%;transform:translate(-50%);clip-path:polygon(38% 0,62% 0,94% 100%,6% 100%)}.path-upper-left{left:22%;top:43%;width:30%;height:4.4rem;transform:rotate(-17deg);border-radius:999px}.path-upper-right{right:22%;top:43%;width:30%;height:4.4rem;transform:rotate(17deg);border-radius:999px}.path-lower-left{left:24%;bottom:22%;width:25%;height:4rem;transform:rotate(17deg);border-radius:999px}.path-lower-right{right:24%;bottom:22%;width:25%;height:4rem;transform:rotate(-17deg);border-radius:999px}.town-game-house{position:absolute;z-index:4;width:clamp(12.5rem,21vw,15.6rem);height:clamp(11.4rem,20vw,14.4rem);border:0;background:transparent;color:#624d43;cursor:pointer;text-align:center;transition:transform .18s ease,filter .18s ease}.town-game-house:hover,.town-game-house:focus-visible{transform:translateY(-8px) rotate(0);filter:saturate(1.06) drop-shadow(0 12px 16px rgba(117,78,61,.14));outline:none}.quiz-cottage{left:15%;top:27%;transform:rotate(-2deg)}.puzzle-cottage{right:15%;top:28%;transform:rotate(1.5deg)}.memory-garden{left:23%;bottom:8%;transform:rotate(1.4deg)}.scratch-stand{right:23%;bottom:8%;transform:rotate(-1.3deg)}.town-house-roof{position:absolute;left:10%;right:10%;top:0;height:42%;clip-path:polygon(50% 0,100% 64%,88% 100%,12% 100%,0 64%);border-radius:22px 22px 10px 10px;background:linear-gradient(135deg,#f39bae,#cfa9f2);box-shadow:0 12px 20px #744d411f}.puzzle-cottage .town-house-roof{background:linear-gradient(135deg,#f2c26b,#8dbdf4)}.memory-garden .town-house-roof{background:linear-gradient(135deg,#d7b7ff,#8fc7f6)}.scratch-stand .town-house-roof{background:linear-gradient(135deg,#f8a49a,#f2c26b)}.town-house-body{position:absolute;inset:32% 17% 18%;display:grid;place-items:center;border:4px solid rgba(255,246,226,.84);border-radius:18px 18px 12px 12px;background:linear-gradient(90deg,transparent 47%,rgba(145,91,72,.12) 48% 52%,transparent 53%),linear-gradient(180deg,#ffe2be,#ffcfd8);box-shadow:inset 0 0 0 2px #ffffff47,0 18px 28px #744d4126}.town-house-window{display:grid;min-width:4.15rem;min-height:3.15rem;place-items:center;border:3px solid rgba(139,89,70,.16);border-radius:12px 12px 6px 6px;background:linear-gradient(90deg,transparent 47%,rgba(139,89,70,.12) 48% 52%,transparent 53%),linear-gradient(180deg,transparent 47%,rgba(139,89,70,.12) 48% 52%,transparent 53%),#fff4b8;color:#a64f5c;font-size:.82rem;font-weight:800}.town-house-door{position:absolute;bottom:0;width:1.85rem;height:2.55rem;border-radius:999px 999px 0 0;background:#a55c4947}.town-house-sign{position:absolute;left:5%;right:5%;bottom:0;display:grid;gap:.18rem;min-height:3.55rem;align-content:center;border:3px solid rgba(150,91,66,.18);border-radius:10px;background:#fff6e2f0;box-shadow:0 8px 16px #744d411f,inset 0 0 0 2px #ffffff57}.town-house-sign strong{color:#9d5160;font-family:Comic Sans MS,Segoe Print,Georgia,serif;font-size:clamp(.96rem,1.9vw,1.13rem);line-height:1.15}.town-house-sign small{justify-self:center;border-radius:999px;background:#f8c9d873;padding:.13rem .68rem;color:#a64f5c;font-size:.78rem}.town-game-house.is-complete .town-house-window{background:radial-gradient(circle,rgba(255,255,255,.88),transparent 45%),#ffe57d;box-shadow:0 0 22px #ffe06c9e}.town-complete-badge{position:absolute;right:8%;top:19%;display:grid;width:2.2rem;height:2.2rem;place-items:center;border-radius:999px;background:#ffe27a;color:#9d6b12;font-size:.66rem;font-weight:800;box-shadow:0 8px 14px #754e3d24}.tree,.bench,.lamp,.mailbox,.bunny,.flower-bed{position:absolute;z-index:2}.tree{width:4.5rem;height:5rem;border-radius:55% 45% 50% 50%;background:radial-gradient(circle at 36% 34%,#bfe37a 0 1.4rem,transparent 1.45rem),radial-gradient(circle at 64% 34%,#93ce68 0 1.5rem,transparent 1.55rem),radial-gradient(circle at 50% 18%,#a8d96f 0 1.4rem,transparent 1.45rem)}.tree:after{position:absolute;left:50%;bottom:-.6rem;width:.72rem;height:2rem;transform:translate(-50%);border-radius:999px;background:#b9875f;content:""}.tree-left{left:6%;bottom:20%}.tree-right{right:7%;bottom:19%}.bench{left:15%;bottom:11%;width:4.8rem;height:2.5rem;border-radius:8px;background:linear-gradient(180deg,transparent 0 36%,#c58b62 37% 50%,transparent 51% 61%,#c58b62 62% 75%,transparent 76%),linear-gradient(90deg,transparent 0 14%,#7a5a4f 15% 19%,transparent 20% 80%,#7a5a4f 81% 85%,transparent 86%)}.lamp{left:5%;bottom:7%;width:.42rem;height:4.8rem;border-radius:999px;background:#6d514c}.lamp:before{position:absolute;left:50%;top:-1.2rem;width:1.45rem;height:1.45rem;transform:translate(-50%);border-radius:999px 999px 45% 45%;background:#ffe18a;box-shadow:0 0 18px #ffe18ab3;content:""}.mailbox{right:16%;bottom:13%;width:3.2rem;height:2.4rem;border-radius:12px 12px 6px 6px;background:#d8899b;box-shadow:inset 0 -.4rem #8e4b5c1f}.mailbox:after{position:absolute;left:45%;top:100%;width:.45rem;height:2.3rem;background:#8b654f;content:""}.bunny{right:5%;bottom:7%;width:3rem;height:2.3rem;border-radius:55% 55% 45% 45%;background:#fff8ef;box-shadow:0 8px 14px #754e3d1a}.bunny:before,.bunny:after{position:absolute;top:-1.15rem;width:.7rem;height:1.55rem;border-radius:999px;background:#fff8ef;content:""}.bunny:before{left:.65rem;transform:rotate(-15deg)}.bunny:after{right:.65rem;transform:rotate(15deg)}.flower-bed{width:10rem;height:3rem;background:radial-gradient(circle at 10% 62%,#f48fa5 0 .28rem,transparent .34rem),radial-gradient(circle at 22% 42%,#ffe07a 0 .3rem,transparent .36rem),radial-gradient(circle at 36% 65%,#d5b5f6 0 .32rem,transparent .38rem),radial-gradient(circle at 54% 48%,#f48fa5 0 .3rem,transparent .36rem),radial-gradient(circle at 76% 62%,#ffe07a 0 .28rem,transparent .34rem);animation:flowerSway 4.6s ease-in-out infinite}.flower-left{left:2%;bottom:2.2%}.flower-right{right:7%;bottom:2.4%;animation-delay:.8s}.town-progress-board{position:absolute;right:clamp(1rem,4vw,3.6rem);bottom:clamp(1rem,4vh,3rem);z-index:5;display:grid;min-width:8.6rem;justify-items:center;gap:.22rem;border:4px solid rgba(151,91,65,.18);border-radius:9px;background:linear-gradient(180deg,#fff6e2f7,#ffe5c9f2),repeating-linear-gradient(90deg,rgba(151,91,65,.04) 0 12px,transparent 12px 24px);padding:.7rem 1rem;box-shadow:0 14px 24px #744d4129}.town-progress-board span,.town-progress-board p{margin:0;color:#624d43b8;font-size:.82rem}.town-progress-board strong{color:#5d464f;font-size:1.85rem;line-height:1}@keyframes cloudDrift{0%,to{transform:translate(0)}50%{transform:translate(10px)}}@keyframes flowerSway{0%,to{transform:rotate(0)}50%{transform:rotate(1.5deg)}}@keyframes modalBackdropIn{0%{opacity:0}to{opacity:1}}@keyframes memoryCardIn{0%{opacity:0;transform:translateY(10px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:767px){.games-town-page{overflow:auto;padding-top:4.25rem}.friendship-town-map{min-height:calc(100vh - 4.25rem);overflow:visible;padding:.9rem .78rem 7.4rem}.town-map-banner{width:min(88vw,330px);padding:.6rem .8rem .78rem}.town-map-banner:before,.town-map-banner:after{display:none}.town-map-banner h1{font-size:2rem}.town-map-banner span:not(.banner-pin){font-size:.82rem}.town-house-layer{display:grid;gap:1.15rem .7rem;grid-template-columns:repeat(2,minmax(0,1fr));margin-top:1.6rem}.town-game-house{position:relative;inset:auto;width:100%;height:11.6rem;transform:none}.town-house-body{left:14%;right:14%}.town-house-sign{left:2%;right:2%}.town-house-sign strong{font-size:.92rem}.town-house-sign small{font-size:.72rem}.town-ferris-wheel{right:-1.8rem;top:9.8rem;width:6.8rem}.cloud-a,.cloud-b,.town-balloon,.tree,.bench,.lamp,.mailbox,.bunny{transform:scale(.72)}.path,.flower-bed{opacity:.58}.town-progress-board{left:50%;right:auto;bottom:1rem;transform:translate(-50%)}}.finale-plaza-page{position:relative;isolation:isolate;min-height:100vh;overflow:hidden auto;padding:6.2rem clamp(1rem,4vw,3rem) 3rem;background:radial-gradient(circle at 18% 18%,rgba(255,223,126,.72) 0 .17rem,transparent .24rem),radial-gradient(circle at 72% 12%,rgba(255,223,126,.5) 0 .14rem,transparent .2rem),radial-gradient(circle at 85% 50%,rgba(255,223,126,.55) 0 .22rem,transparent .29rem),radial-gradient(circle at 36% 58%,rgba(248,201,216,.62) 0 .32rem,transparent .42rem),linear-gradient(180deg,#273d7c,#51699f 46%,#e7dff2 75%,#fff1dd)}.finale-video-backdrop{position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none;background:radial-gradient(circle at 50% 32%,rgba(248,201,216,.2),transparent 26rem),linear-gradient(180deg,#24355f,#402f5a)}.finale-video-backdrop video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;filter:blur(10px);opacity:.9;transform:scale(1.08);transform-origin:center}.finale-video-backdrop:after{position:absolute;inset:0;background:radial-gradient(circle at 50% 18%,rgba(255,231,181,.14),transparent 24rem),linear-gradient(180deg,#1f224c85,#5d396780 52%,#ffcadc47);content:""}.finale-plaza-page>:not(.finale-video-backdrop){position:relative;z-index:2}.finale-plaza-page:before{position:absolute;inset:0;z-index:1;background:radial-gradient(circle at 50% 25%,rgba(255,244,220,.18),transparent 22rem),linear-gradient(90deg,rgba(255,255,255,.05),transparent 18%,transparent 82%,rgba(255,255,255,.05));content:"";pointer-events:none}.finale-plaza-page:after{position:absolute;left:-8%;right:-8%;bottom:-7rem;z-index:1;height:19rem;border-radius:50% 50% 0 0/34% 34% 0 0;background:radial-gradient(circle at 16% 38%,#ffd66c 0 .32rem,transparent .4rem),radial-gradient(circle at 24% 48%,#f4a0b2 0 .32rem,transparent .4rem),radial-gradient(circle at 78% 42%,#d8b5ff 0 .34rem,transparent .42rem),linear-gradient(180deg,#82c777b8,#6daf68c7);content:"";pointer-events:none}.finale-stage{position:relative;z-index:2;width:min(100%,1160px);margin:0 auto}.finale-hero-card{position:relative;display:grid;min-height:25rem;align-items:center;gap:clamp(1.5rem,4vw,3rem);grid-template-columns:minmax(0,1.05fr) minmax(260px,.72fr);overflow:hidden;border:5px solid rgba(255,248,236,.72);border-radius:30px;background:radial-gradient(circle at 74% 34%,rgba(255,231,145,.24),transparent 13rem),linear-gradient(135deg,#fff8eceb,#ffe5edc7);padding:clamp(1.4rem,4vw,3rem);box-shadow:0 34px 80px #131e4942}.finale-hero-card:before{position:absolute;left:-12%;right:-12%;bottom:-7.8rem;height:13rem;border-radius:50% 50% 0 0;background:radial-gradient(circle at 18% 40%,#ffd56d 0 .32rem,transparent .4rem),radial-gradient(circle at 28% 34%,#f597aa 0 .32rem,transparent .4rem),linear-gradient(180deg,#b5df85,#76bf70);content:""}.finale-hero-copy{position:relative;z-index:1;max-width:40rem}.finale-ticket{display:inline-flex;min-height:2rem;align-items:center;border:2px dashed rgba(201,143,45,.36);border-radius:999px;background:#fff8ecb3;padding:0 .8rem;color:#c58f2a;font-size:.78rem;font-weight:900;letter-spacing:.16em}.finale-hero-card h1,.finale-locked-card h1{margin-top:.75rem;color:#9d5160;font-family:Comic Sans MS,Segoe Print,Georgia,serif;font-size:clamp(2.7rem,7vw,5.8rem);font-weight:900;line-height:1;text-shadow:0 3px 0 rgba(255,255,255,.52)}.finale-hero-card p,.finale-locked-card p{margin-top:1rem;color:#594550bd;font-size:clamp(1rem,2vw,1.18rem);line-height:1.9}.finale-gift-stage{position:relative;z-index:1;display:grid;min-height:18rem;place-items:center}.finale-gift-stage:before{position:absolute;inset:8% 4% auto;height:72%;background:radial-gradient(circle,rgba(255,225,128,.48),transparent 66%);filter:blur(12px);content:""}.finale-gift{position:relative;display:block;width:min(60vw,220px);height:min(60vw,220px);border:0;background:transparent;cursor:pointer;filter:drop-shadow(0 28px 34px rgba(85,51,84,.2))}.finale-gift-body,.finale-gift-lid,.finale-gift-ribbon{position:absolute;left:50%;display:block;transform:translate(-50%)}.finale-gift-body{bottom:14%;width:74%;height:58%;border:5px solid rgba(255,248,236,.38);border-radius:22px;background:linear-gradient(90deg,transparent 43%,rgba(255,255,255,.46) 43% 57%,transparent 57%),linear-gradient(135deg,#f8c9d8,#d9c7f2);box-shadow:inset 0 -1.1rem #774f7014}.finale-gift-lid{bottom:71%;width:86%;height:26%;border:5px solid rgba(255,248,236,.38);border-radius:18px;background:linear-gradient(90deg,transparent 44%,rgba(255,255,255,.44) 44% 56%,transparent 56%),linear-gradient(135deg,#e7c777,#f8c9d8);transform-origin:16% 100%;transition:transform .26s ease}.finale-gift-ribbon{bottom:86%;width:64%;height:30%}.finale-gift-ribbon:before,.finale-gift-ribbon:after{position:absolute;top:0;width:46%;height:100%;border:10px solid #e7c777;border-radius:999px 999px 999px 8px;content:""}.finale-gift-ribbon:before{left:0;transform:rotate(-28deg)}.finale-gift-ribbon:after{right:0;transform:scaleX(-1) rotate(-28deg)}.finale-gift:hover .finale-gift-lid,.finale-gift:focus-visible .finale-gift-lid,.finale-gift.is-opened .finale-gift-lid{transform:translate(-57%) translateY(-28px) rotate(-13deg)}.finale-gift:focus-visible{outline:3px solid rgba(231,199,119,.72);outline-offset:8px;border-radius:26px}.finale-burst{position:absolute;inset:50%;pointer-events:none}.finale-ending-line{display:grid;justify-items:center;gap:.3rem;margin:clamp(1.4rem,4vw,2.4rem) auto;color:#fff8ef;text-align:center;text-shadow:0 2px 20px rgba(27,38,82,.36)}.finale-ending-line span{color:#fff8efc7;font-size:.95rem;font-weight:800;letter-spacing:.2em}.finale-ending-line strong{font-family:Comic Sans MS,Segoe Print,Georgia,serif;font-size:clamp(2.4rem,6vw,5rem);font-weight:900;line-height:1}.finale-main-grid{display:grid;align-items:stretch;gap:clamp(1rem,3vw,1.4rem);grid-template-columns:minmax(0,.9fr) minmax(280px,1.1fr)}.future-letter-card,.finale-illustration-card,.finale-locked-card{position:relative;overflow:hidden;border:5px solid rgba(255,248,236,.84);border-radius:24px;background:linear-gradient(#fffdf9e6,#fffdf9e6),repeating-linear-gradient(0deg,transparent 0 2.2rem,rgba(143,174,214,.13) 2.25rem);box-shadow:0 26px 60px #131e4938}.future-letter-card{padding:clamp(1.2rem,4vw,2rem)}.future-letter-card:before{position:absolute;inset:0 auto 0 1.35rem;width:2px;background:#f8c9d8c7;content:""}.future-letter-card h2{color:#765166;font-family:Comic Sans MS,Segoe Print,Georgia,serif;font-size:clamp(1.8rem,4vw,3rem);font-weight:800}.future-letter-card p{margin-top:1rem;color:#594550b8;font-size:1rem;line-height:2}.finale-stamp{position:absolute;right:1rem;top:1rem;display:inline-flex;min-height:2.2rem;align-items:center;border:2px dashed rgba(166,79,92,.28);border-radius:10px;padding:0 .72rem;color:#a64f5c;font-size:.75rem;font-weight:900;transform:rotate(4deg)}.finale-illustration-card{min-height:22rem;padding:.72rem;background:#fff8ece6}.finale-illustration-card img{display:block;width:100%;height:100%;min-height:22rem;border-radius:18px;-o-object-fit:cover;object-fit:cover;box-shadow:0 18px 34px #7953481f}.finale-ticket-row{display:grid;gap:.5rem;grid-template-columns:repeat(3,minmax(0,1fr));margin-top:1rem;border:3px dashed rgba(255,248,236,.55);border-radius:18px;background:#fff8ec2e;padding:.9rem;color:#fff8efdb;text-align:center;font-weight:800;letter-spacing:.08em;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.finale-town-silhouette{position:absolute;left:0;right:0;bottom:0;z-index:-1;height:17rem;pointer-events:none}.finale-house,.finale-lamp,.finale-string-light{position:absolute;bottom:0;display:block}.finale-house{width:7rem;height:6rem;border-radius:18px 18px 0 0;background:radial-gradient(circle at 32% 48%,#ffe38c 0 .5rem,transparent .58rem),linear-gradient(180deg,#6f5780,#4c456e);box-shadow:inset 0 0 0 4px #fff8ec14}.finale-house:before{position:absolute;left:12%;right:12%;top:-2.2rem;height:3.2rem;clip-path:polygon(50% 0,100% 72%,88% 100%,12% 100%,0 72%);background:#d8899b;content:""}.house-one{left:8%;transform:scale(.9)}.house-two{left:22%;transform:scale(1.08)}.house-three{right:10%;transform:scale(.98)}.finale-lamp{width:.36rem;height:5.2rem;border-radius:999px;background:#fff8ec85}.finale-lamp:before{position:absolute;left:50%;top:-1.35rem;width:1.55rem;height:1.55rem;transform:translate(-50%);border-radius:999px 999px 45% 45%;background:#ffe18a;box-shadow:0 0 22px #ffe18acc;content:""}.lamp-one{left:4%}.lamp-two{right:25%;transform:scale(.86)}.finale-string-light{left:45%;right:6%;bottom:7rem;height:4rem;border-top:2px solid rgba(255,248,236,.32);border-radius:50%}.finale-string-light:before{position:absolute;inset:0;background:radial-gradient(circle at 18% 26%,#ffe18a 0 .28rem,transparent .35rem),radial-gradient(circle at 42% 10%,#f8c9d8 0 .28rem,transparent .35rem),radial-gradient(circle at 66% 18%,#d9c7f2 0 .28rem,transparent .35rem),radial-gradient(circle at 88% 34%,#ffe18a 0 .28rem,transparent .35rem);content:""}.finale-is-locked{display:grid;place-items:center}.finale-locked-card{width:min(100%,680px);padding:clamp(1.4rem,5vw,2.4rem);text-align:center}@media(max-width:767px){.finale-plaza-page{padding:5.2rem .85rem 2rem}.finale-hero-card,.finale-main-grid,.finale-illustration-card,.finale-ticket-row{grid-template-columns:1fr}.finale-hero-card{min-height:0;border-width:4px;border-radius:24px}.finale-hero-card h1,.finale-locked-card h1{font-size:2.8rem}.finale-gift-stage{min-height:13rem}.finale-illustration-card,.finale-illustration-card img{min-height:18rem}.finale-stamp{position:static;width:-moz-fit-content;width:fit-content;margin-bottom:.7rem}.finale-ticket-row{font-size:.82rem}}.site-header-inner{grid-template-columns:minmax(150px,.85fr) minmax(520px,auto) minmax(150px,.85fr)}.nav-link{padding-inline:.72rem}.moments-town-page{min-height:100vh;padding:6rem clamp(1rem,4vw,3rem) 4rem;background:radial-gradient(circle at 8% 16%,rgba(255,255,255,.88) 0 2rem,transparent 2.08rem),radial-gradient(circle at 16% 13%,rgba(255,255,255,.88) 0 2.7rem,transparent 2.8rem),radial-gradient(circle at 88% 12%,rgba(255,255,255,.82) 0 2.4rem,transparent 2.5rem),linear-gradient(180deg,#bfe7ff,#e7f6ff 32%,#fff5df 32.4%,#ffe8ef)}.login-town-page{display:grid;min-height:100vh;place-items:center;padding:6rem clamp(1rem,4vw,3rem) 3rem;background:radial-gradient(circle at 18% 18%,rgba(255,255,255,.88) 0 2.2rem,transparent 2.3rem),radial-gradient(circle at 80% 16%,rgba(255,255,255,.82) 0 2.8rem,transparent 2.9rem),linear-gradient(180deg,#bfe7ff,#e7f6ff 34%,#fff5df 34.4%,#ffe8ef)}.login-post-office{position:relative;width:min(100%,560px);border:3px solid rgba(151,91,65,.15);border-radius:24px;background:linear-gradient(135deg,#fffdf9f0,#ffefe5e0),repeating-linear-gradient(0deg,transparent 0 2.4rem,rgba(143,174,214,.12) 2.44rem);padding:clamp(1.25rem,4vw,2rem);box-shadow:0 28px 70px #79534829}.login-post-office h1{margin-top:.35rem;color:#9d5160;font-family:Comic Sans MS,Segoe Print,Georgia,serif;font-size:clamp(2.2rem,6vw,3.8rem);font-weight:900;line-height:1}.login-post-office>p:not(.auth-kicker):not(.moments-notice){margin-top:.85rem;color:#594550ad;line-height:1.8}.login-form{display:grid;gap:.9rem;margin-top:1.2rem}.login-form label{display:grid;gap:.38rem;color:#594550a8;font-size:.9rem;font-weight:700}.login-form input{min-height:3.1rem;border:1px solid rgba(151,91,65,.16);border-radius:13px;background:#ffffffc2;padding:0 .9rem;color:#594550;outline:none}.login-form input:focus{border-color:#e771857a;box-shadow:0 0 0 4px #f8c9d842}.moments-hero,.moments-action-bar,.moment-timeline,.latest-moments-panel{width:min(100%,1120px);margin-inline:auto}.moments-hero{position:relative;display:grid;min-height:15rem;align-items:center;gap:1.2rem;grid-template-columns:minmax(0,1fr) minmax(220px,.52fr);overflow:hidden;border:3px solid rgba(151,91,65,.16);border-radius:26px;background:radial-gradient(circle at 80% 18%,rgba(255,255,255,.65),transparent 9rem),linear-gradient(135deg,#fff8ecf0,#ffe2ecdb);padding:clamp(1.25rem,4vw,2.4rem);box-shadow:0 24px 54px #79534821}.moments-hero:after{position:absolute;left:-8%;right:-8%;bottom:-5.4rem;height:8rem;border-radius:50% 50% 0 0;background:radial-gradient(circle at 12% 42%,#f48fa5 0 .3rem,transparent .38rem),radial-gradient(circle at 22% 32%,#ffd86f 0 .34rem,transparent .42rem),radial-gradient(circle at 70% 38%,#d5b5f6 0 .32rem,transparent .4rem),linear-gradient(180deg,#b7dd86,#8bc978);content:""}.moments-hero-copy{position:relative;z-index:1}.moments-hero h1{margin-top:.25rem;color:#a64f5c;font-family:Comic Sans MS,Segoe Print,Georgia,serif;font-size:clamp(2.5rem,7vw,5rem);font-weight:800;line-height:1}.moments-hero p{margin-top:.9rem;max-width:34rem;color:#594550b8;font-size:clamp(1rem,2.2vw,1.2rem);line-height:1.85}.moments-hero-art{position:relative;z-index:1;min-height:12rem}.postbox{position:absolute;left:18%;bottom:12%;width:8.4rem;height:6.2rem;border:4px solid rgba(141,75,76,.12);border-radius:34px 34px 14px 14px;background:linear-gradient(180deg,#ef8da2,#d66f86);box-shadow:inset 0 -.75rem #8e4b5c1f,0 18px 26px #79534824}.postbox:before{position:absolute;left:1.25rem;right:1.25rem;top:1.75rem;height:.55rem;border-radius:999px;background:#fffdf9e0;content:""}.postbox:after{position:absolute;left:44%;top:100%;width:.75rem;height:3.2rem;border-radius:999px;background:#8b654f;content:""}.camera-doodle{position:absolute;right:6%;top:12%;width:7.2rem;height:5rem;transform:rotate(5deg);border:4px solid rgba(89,69,80,.14);border-radius:18px;background:linear-gradient(180deg,#fff7dd,#f3c988);box-shadow:0 14px 22px #7953481f}.camera-doodle:before{position:absolute;left:2.2rem;top:1.12rem;width:2.25rem;height:2.25rem;border:.42rem solid #8fc7f6;border-radius:999px;background:#fffdf9;content:""}.camera-doodle:after{position:absolute;right:.9rem;top:.75rem;width:.82rem;height:.82rem;border-radius:999px;background:#f48fa5;content:""}.paperclip{position:absolute;display:block;width:3rem;height:4.2rem;border:5px solid rgba(170,111,146,.35);border-radius:999px}.paperclip.one{right:42%;top:7%;transform:rotate(-14deg)}.paperclip.two{right:18%;bottom:16%;transform:rotate(19deg) scale(.72);border-color:#da9d4859}.moments-action-bar{display:grid;align-items:stretch;gap:1rem;grid-template-columns:minmax(0,1fr) minmax(150px,190px);margin-top:1.1rem}.auth-postcard{position:relative;display:grid;align-items:center;gap:.85rem 1rem;grid-template-columns:minmax(280px,1fr) minmax(140px,.16fr) minmax(170px,.22fr) minmax(128px,auto);border:2px solid rgba(151,91,65,.14);border-radius:16px;background:linear-gradient(90deg,transparent 0 68%,rgba(248,201,216,.2) 68.2%),#fffdf9c7;padding:1rem 1.18rem;box-shadow:0 18px 36px #7953481a;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.auth-postcard.is-logged-in{grid-template-columns:minmax(0,1fr) auto}.auth-postcard strong{display:block;color:#80515a;font-family:Comic Sans MS,Segoe Print,Georgia,serif;font-size:1.2rem}.auth-postcard span:not(.postcard-stamp){display:block;margin-top:.22rem;color:#5945509e;font-size:.9rem}.auth-kicker{margin:0;color:#c58f2a;font-size:.76rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase}.postcard-stamp{position:absolute;right:1rem;top:-.78rem;display:inline-flex;min-height:2rem;align-items:center;border:2px dashed rgba(166,79,92,.28);border-radius:10px;background:#fffdf9eb;padding:0 .72rem;color:#a64f5c;font-size:.75rem;font-weight:800;transform:rotate(3deg)}.auth-postcard label,.moment-form-card label{display:grid;gap:.36rem;color:#594550a8;font-size:.88rem;font-weight:700}.auth-postcard input,.auth-postcard select,.moment-form-card input,.moment-form-card textarea{min-height:2.9rem;width:100%;border:1px solid rgba(151,91,65,.16);border-radius:12px;background:#ffffffbd;padding:0 .82rem;color:#594550;outline:none}.auth-postcard input:focus,.auth-postcard select:focus,.moment-form-card input:focus,.moment-form-card textarea:focus{border-color:#e771857a;box-shadow:0 0 0 4px #f8c9d842}.auth-submit,.record-today-button{margin:0;white-space:nowrap}.auth-submit{min-width:7.2rem;justify-self:stretch}.record-today-button{min-height:100%;width:100%;border:2px solid rgba(255,255,255,.7);border-radius:16px;background:linear-gradient(135deg,#f28fa4,#d8b5ff);padding:0 1.45rem;color:#fffdf9;font-size:1.05rem;font-weight:800;box-shadow:0 18px 36px #79534821;transition:transform .17s ease,filter .17s ease}.record-today-button:hover,.record-today-button:focus-visible{transform:translateY(-2px);filter:saturate(1.06);outline:none}.moments-notice,.form-message{width:min(100%,1120px);margin:.9rem auto 0;border:1px solid rgba(231,113,133,.28);border-radius:12px;background:#fffdf9c7;padding:.8rem 1rem;color:#a64f5c}.moment-timeline{display:grid;gap:1rem;margin-top:1.2rem}.moment-entry,.empty-moments,.latest-moments-panel{border:2px solid rgba(151,91,65,.13);border-radius:18px;background:linear-gradient(135deg,#fffdf9e0,#ffefe5d1),repeating-linear-gradient(0deg,transparent 0 2.5rem,rgba(143,174,214,.12) 2.54rem);box-shadow:0 18px 40px #7953481c}.moment-entry{overflow:hidden;padding:clamp(1rem,3vw,1.25rem)}.moment-entry-main{display:grid;align-items:start;gap:1rem;grid-template-columns:9rem minmax(0,1fr) auto}.moment-entry h2{margin-top:.25rem;color:#9d5160;font-family:Comic Sans MS,Segoe Print,Georgia,serif;font-size:clamp(1.35rem,3vw,1.8rem);font-weight:800}.moment-entry p:not(.auth-kicker){margin-top:.45rem;color:#594550b8;line-height:1.8}.moment-date-badge{display:grid;min-height:5.4rem;align-content:center;justify-items:center;border:2px dashed rgba(166,79,92,.28);border-radius:14px;background:#fff8eccc;color:#a64f5c;transform:rotate(-1.2deg)}.moment-date-badge span{font-weight:900}.moment-date-badge small{margin-top:.24rem;color:#5945508f}.moment-actions{display:flex;gap:.5rem}.moment-actions button{min-height:2.35rem;border-radius:999px;background:#f8c9d85c;padding:0 .8rem;color:#8f514b;font-size:.86rem;font-weight:800}.moment-photos{display:grid;gap:.7rem;grid-template-columns:repeat(6,minmax(0,1fr));margin-top:1rem}.moment-thumb{aspect-ratio:1;overflow:hidden;border:6px solid rgba(255,253,249,.94);border-radius:12px;background:#ffffff94;box-shadow:0 12px 20px #7953481c;transition:transform .16s ease,box-shadow .16s ease}.moment-thumb:nth-child(odd){transform:rotate(-1deg)}.moment-thumb:nth-child(2n){transform:rotate(1.2deg)}.moment-thumb:hover,.moment-thumb:focus-visible{transform:rotate(0) translateY(-3px);box-shadow:0 18px 26px #79534829;outline:none}.moment-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.empty-moments{position:relative;min-height:13rem;padding:clamp(1.3rem,4vw,2rem)}.empty-moments h2{color:#9d5160;font-family:Comic Sans MS,Segoe Print,Georgia,serif;font-size:clamp(1.5rem,4vw,2rem)}.empty-moments p{margin-top:.5rem;color:#594550ad}.moment-form-backdrop{position:fixed;inset:0;z-index:130;display:grid;place-items:center;overflow-y:auto;background:#3628318c;padding:clamp(1rem,4vw,2rem);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.moment-form-card{position:relative;display:grid;width:min(100%,680px);gap:.9rem;border:3px solid rgba(151,91,65,.15);border-radius:20px;background:linear-gradient(135deg,#fffdf9fa,#ffeee2f5),repeating-linear-gradient(0deg,transparent 0 2.4rem,rgba(143,174,214,.12) 2.44rem);padding:clamp(1rem,4vw,1.5rem);box-shadow:0 30px 80px #402d3847;animation:memoryCardIn .22s cubic-bezier(.2,.85,.28,1) both}.moment-form-head{display:flex;align-items:center;gap:.85rem}.moment-form-head .postcard-stamp{position:static}.moment-form-head h2{color:#9d5160;font-family:Comic Sans MS,Segoe Print,Georgia,serif;font-size:clamp(1.55rem,4vw,2.2rem);font-weight:800}.file-drop{min-height:7rem;place-items:center;border:2px dashed rgba(166,79,92,.28);border-radius:16px;background:#f8c9d82e;padding:1rem;text-align:center;cursor:pointer}.file-drop input{position:absolute;width:1px;height:1px;opacity:0}.file-drop strong{color:#9d5160;font-size:1.05rem}.file-drop span{color:#59455094;font-size:.9rem}.moment-form-grid{display:grid;gap:.8rem;grid-template-columns:repeat(2,minmax(0,1fr))}.moment-form-card textarea{min-height:8rem;resize:vertical;padding-top:.82rem}.char-count{justify-self:end;color:#59455080;font-size:.78rem}.moment-form-actions{display:flex;justify-content:flex-end;gap:.7rem}.soft-button.secondary{background:#fffdf9e0;color:#80515a}.latest-moments-panel{display:grid;align-items:center;gap:1rem;grid-template-columns:minmax(180px,.52fr) minmax(0,1fr) auto;margin-top:1rem;margin-bottom:1.8rem;padding:1rem;position:relative;z-index:2}.latest-moments-panel h2{margin-top:.1rem;color:#9d5160;font-family:Comic Sans MS,Segoe Print,Georgia,serif;font-size:clamp(1.35rem,3vw,1.8rem);font-weight:800}.latest-moments-panel p{color:#594550a8}.latest-moment-list{display:grid;gap:.65rem;grid-template-columns:repeat(3,minmax(0,1fr))}.latest-moment-card{display:grid;align-items:center;gap:.62rem;grid-template-columns:3.9rem minmax(0,1fr);min-height:4.7rem;border:1px solid rgba(151,91,65,.12);border-radius:14px;background:#fffdf9b8;padding:.45rem;color:#594550;text-decoration:none;box-shadow:0 10px 20px #79534814;transition:transform .16s ease,box-shadow .16s ease}.latest-moment-card:hover,.latest-moment-card:focus-visible{transform:translateY(-2px);box-shadow:0 16px 28px #79534821;outline:none}.latest-moment-card img{width:3.9rem;height:3.9rem;border:4px solid rgba(255,248,236,.95);border-radius:10px;-o-object-fit:cover;object-fit:cover}.latest-moment-card span{display:grid;min-width:0;gap:.15rem}.latest-moment-card strong,.latest-moment-card small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.latest-moment-card strong{color:#9d5160;font-size:.92rem}.latest-moment-card small{color:#5945508f;font-size:.78rem}.latest-moment-photos{display:flex;align-items:center;padding-right:.5rem}.latest-moment-photos img{width:4.4rem;height:4.4rem;margin-left:-.72rem;transform:rotate(var(--tilt, -3deg));border:5px solid rgba(255,253,249,.96);border-radius:12px;-o-object-fit:cover;object-fit:cover;box-shadow:0 10px 18px #7953481f}.latest-moment-photos img:nth-child(2){--tilt: 4deg}.latest-moment-photos img:nth-child(3){--tilt: -1deg}.latest-moments-panel+.memories-town-page{padding-top:clamp(4.5rem,8vw,6.5rem)}@media(max-width:1120px){.site-header-inner{grid-template-columns:minmax(140px,.7fr) minmax(460px,auto) minmax(130px,.7fr)}.nav-link{padding-inline:.54rem;font-size:.84rem}.progress-pill{font-size:.8rem}.moments-action-bar{grid-template-columns:1fr}.auth-postcard{grid-template-columns:minmax(0,1fr) minmax(130px,.35fr) minmax(160px,.4fr) minmax(118px,auto)}.record-today-button{min-height:3.5rem}.latest-moments-panel{grid-template-columns:1fr}}@media(min-width:1121px)and (max-width:1380px){.auth-postcard{grid-template-columns:minmax(0,1fr) minmax(130px,.25fr) minmax(160px,.3fr) minmax(118px,auto)}.auth-postcard strong{font-size:1.08rem}}@media(max-width:767px){.site-header-inner{grid-template-columns:minmax(0,1fr) auto}.moments-town-page{padding:5.2rem .85rem 3rem}.moments-hero{min-height:0;grid-template-columns:1fr;border-radius:22px;padding:1rem}.moments-hero h1{font-size:2.65rem}.moments-hero-art{min-height:7.6rem}.postbox{left:6%;width:6.4rem;height:4.8rem}.camera-doodle{right:4%;width:5.6rem;height:4rem}.moments-action-bar,.auth-postcard,.moment-entry-main,.latest-moments-panel{grid-template-columns:1fr}.auth-postcard{padding-top:3rem}.record-today-button{min-height:3.4rem}.moment-entry-main{gap:.75rem}.moment-date-badge{width:min(100%,10rem);min-height:4.6rem}.moment-actions{justify-content:flex-start}.moment-photos{grid-template-columns:repeat(3,minmax(0,1fr))}.moment-form-grid,.moment-form-actions{grid-template-columns:1fr}.moment-form-actions{display:grid}.latest-moments-panel{margin-top:.7rem;margin-bottom:1.2rem}.latest-moment-list{grid-template-columns:1fr}}.letter-town-page{min-height:100vh;overflow:hidden auto;padding:clamp(5.4rem,8vw,7rem) clamp(1rem,4vw,3.5rem) 4rem;background:radial-gradient(circle at 10% 18%,rgba(255,255,255,.88) 0 2.1rem,transparent 2.18rem),radial-gradient(circle at 90% 14%,rgba(255,255,255,.8) 0 2.6rem,transparent 2.7rem),linear-gradient(180deg,#cbeeff 0 18rem,#fff1df 18.05rem 100%)}.letter-shell{position:relative;width:min(100%,1220px);margin:0 auto}.letter-shell:before,.letter-shell:after{content:"";position:absolute;z-index:0;border-radius:999px;pointer-events:none}.letter-shell:before{left:-5rem;top:17rem;width:10rem;height:10rem;background:#f7afc133;filter:blur(10px)}.letter-shell:after{right:-4rem;bottom:8rem;width:9rem;height:9rem;background:#d7c5f242;filter:blur(12px)}.letter-hero-card{position:relative;z-index:1;display:flex;align-items:center;aspect-ratio:var(--letter-video-ratio, 16 / 9);width:min(100%,1120px);min-height:auto;margin:0 auto;overflow:hidden;border:4px solid rgba(255,250,239,.92);border-radius:34px;background:radial-gradient(circle at 78% 42%,rgba(248,201,216,.32),transparent 18rem),linear-gradient(135deg,#fff8ef,#ffeaf1);box-shadow:0 26px 70px #8e5b7529;padding:clamp(1.4rem,4vw,3.5rem)}.letter-card-video-bg{position:absolute;left:50%;top:50%;z-index:0;width:calc(100% / var(--letter-video-ratio-number, 1.7778));height:calc(100% * var(--letter-video-ratio-number, 1.7778));-o-object-fit:contain;object-fit:contain;transform:translate(-50%,-50%) rotate(-90deg);transform-origin:center}.letter-hero-card:before{content:none}.letter-hero-card:after{content:"";position:absolute;inset:0;z-index:1;background:#fffaef47;pointer-events:none}.letter-hero-copy{position:relative;z-index:3;max-width:31rem}.letter-kicker{margin-bottom:.8rem;color:#cf9120;font-family:Trebuchet MS,Microsoft YaHei,sans-serif;font-size:clamp(.78rem,1.2vw,.95rem);font-weight:900;letter-spacing:.24em}.letter-hero-copy h1{color:#a94c62;font-family:STXingkai,KaiTi,"FangSong",Microsoft YaHei,serif;font-size:clamp(3.2rem,8.4vw,7.8rem);font-weight:700;letter-spacing:0;line-height:.95;text-shadow:0 8px 26px rgba(169,76,98,.12)}.letter-title-sr{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;clip-path:inset(50%)}.letter-title-marquee{position:relative;width:min(100%,36rem);margin:.35rem 0 0;overflow:hidden;border-block:1px solid rgba(169,76,98,.16);padding:.18rem 0 .38rem;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}.letter-title-parallax{position:relative;overflow:hidden}.letter-title-scroller{display:flex;width:-moz-max-content;width:max-content;align-items:center;white-space:nowrap;animation:letter-title-marquee 28s linear infinite}.letter-scroll-title{flex-shrink:0;color:#a94c62;font-family:STXingkai,KaiTi,"FangSong",Microsoft YaHei,serif;font-size:clamp(2.75rem,7.2vw,6.7rem);font-weight:700;letter-spacing:.02em;line-height:1.05;padding-right:clamp(1.2rem,3vw,2.4rem);text-shadow:0 8px 24px rgba(169,76,98,.12),0 1px 0 rgba(255,248,236,.82)}@keyframes letter-title-marquee{0%{transform:translateZ(0)}to{transform:translate3d(-50%,0,0)}}.letter-hero-copy p:not(.letter-kicker){max-width:28rem;margin-top:1.15rem;color:#594550bd;font-size:clamp(1rem,1.8vw,1.3rem);line-height:1.9}.letter-stage{position:relative;z-index:1;display:grid;grid-template-columns:minmax(14rem,.42fr) minmax(0,1fr);gap:clamp(1.1rem,3vw,2rem);width:min(100%,1120px);margin:clamp(1.4rem,4vw,2.5rem) auto 0;align-items:start}.letter-side-note{position:sticky;top:6.4rem;overflow:hidden;border:3px solid rgba(255,250,239,.9);border-radius:26px;background:linear-gradient(180deg,#fffaeff2,#ffecdbe6),repeating-linear-gradient(-10deg,transparent 0 1rem,rgba(255,212,222,.28) 1rem 1.08rem);box-shadow:0 18px 42px #8f5b751f;padding:1.3rem}.letter-side-note:after{content:"";position:absolute;right:-1.6rem;bottom:-1.8rem;width:8rem;height:8rem;border-radius:999px;background:#d9c7f24d}.letter-stamp{display:inline-grid;width:4.5rem;height:4.5rem;margin-bottom:1rem;place-items:center;transform:rotate(-9deg);border:2px dashed rgba(188,85,105,.42);border-radius:999px;color:#a94c62;font-family:Georgia,Times New Roman,serif;font-size:1.3rem;font-weight:900}.letter-side-note h2{position:relative;z-index:1;color:#9d4e61;font-family:KaiTi,Microsoft YaHei,serif;font-size:clamp(1.55rem,2.3vw,2.1rem);line-height:1.2}.letter-side-note p{position:relative;z-index:1;margin-top:.85rem;color:#594550ad;font-size:.98rem;line-height:1.85}.letter-paper{position:relative;overflow:hidden;border:3px solid rgba(255,250,239,.92);border-radius:26px;background:linear-gradient(90deg,rgba(235,122,151,.48) 0 2px,transparent 2px 100%),linear-gradient(#fffdf7e0,#fffdf7e0),repeating-linear-gradient(0deg,transparent 0,transparent 2.55rem,rgba(209,183,205,.26) 2.6rem);box-shadow:0 24px 68px #8f5b7526;padding:clamp(1.4rem,4vw,3.2rem)}.letter-paper:before{content:"";position:absolute;right:1.8rem;top:1.6rem;width:6.2rem;height:6.2rem;transform:rotate(12deg);border:2px dashed rgba(207,145,32,.24);border-radius:22px;background:#ffde842e}.letter-paper-header{position:relative;z-index:1;display:flex;justify-content:space-between;gap:1rem;border-bottom:1px dashed rgba(169,76,98,.22);color:#a94c62b8;font-family:Trebuchet MS,Microsoft YaHei,sans-serif;font-size:.88rem;font-weight:900;letter-spacing:.08em;padding-bottom:.9rem;text-transform:uppercase}.letter-copy{position:relative;z-index:1;margin-top:clamp(1.2rem,3vw,2rem);color:#46313bd6;font-family:"FangSong",KaiTi,Microsoft YaHei,serif;font-size:clamp(1rem,1.32vw,1.18rem);line-height:2.24}.letter-copy p+p{margin-top:.74rem}.letter-first-line:first-letter{float:left;margin:.18rem .45rem 0 0;color:#a94c62;font-family:STXingkai,KaiTi,serif;font-size:3.4rem;line-height:.88}.letter-signature{position:relative;z-index:1;margin-top:2rem;color:#46313bcc;font-family:KaiTi,Microsoft YaHei,serif;font-size:1.15rem;line-height:1.8;text-align:right}@media(max-width:980px){.letter-stage{grid-template-columns:1fr}.letter-hero-card{min-height:0}.letter-side-note{position:relative;top:auto}}@media(max-width:640px){.letter-town-page{padding:5.2rem .85rem 3rem}.letter-hero-card{border-radius:24px;padding:1.1rem 1rem 1.4rem}.letter-hero-copy h1{font-size:clamp(2.8rem,16vw,4.2rem)}.letter-stage{gap:.9rem}.letter-side-note,.letter-paper{border-radius:22px}.letter-paper{padding:1.25rem}.letter-paper-header{display:grid}.letter-copy{font-size:1rem;line-height:2.05}}@media(min-width:640px){.sm\:mb-12{margin-bottom:3rem}.sm\:text-4xl{font-size:2.25rem;line-height:2.5rem}.sm\:text-base{font-size:1rem;line-height:1.5rem}.sm\:text-lg{font-size:1.125rem;line-height:1.75rem}}@media(min-width:1024px){.lg\:mx-0{margin-left:0;margin-right:0}.lg\:text-left{text-align:left}}
