:root{--cream: #fff7f0;--cream-strong: #f6e2cc;--rose: #f27d8f;--rose-deep: #b65f4a;--leaf: #7b8f5a;--leaf-dark: #2f3a2f;--bark: #6d3e2d;--paper: rgba(255, 247, 240, .82);--paper-solid: #fffaf5;--line: rgba(109, 62, 45, .22);--shadow: 0 24px 70px rgba(88, 58, 34, .2);--font-body: "LXGW WenKai", "Noto Serif SC", "Songti SC", serif;--font-display: "Cormorant Garamond", "LXGW WenKai", "Songti SC", serif;color:var(--leaf-dark);background:var(--cream);font-family:var(--font-body);font-synthesis:none;text-rendering:geometricPrecision}*{box-sizing:border-box}html{min-height:100%}body{min-height:100%;margin:0;overflow-x:hidden}body:has(.story-viewer){overflow:hidden}body,button{font-family:var(--font-body)}button,a{-webkit-tap-highlight-color:transparent}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}.page-shell{position:relative;min-height:100vh;min-height:100dvh;overflow:hidden;background:linear-gradient(90deg,#fff7f0f5,#fff7f06b 50%,#fff7f00f),url(/assets/garden-bg.jpg) center / cover no-repeat}.page-shell:before{position:absolute;inset:0;pointer-events:none;content:"";background:linear-gradient(180deg,#fff7f00f,#2f3a2f1f),repeating-linear-gradient(108deg,rgba(109,62,45,.035) 0,rgba(109,62,45,.035) 1px,transparent 1px,transparent 9px);mix-blend-mode:multiply}.home-page,.event-page{isolation:isolate}.home-content{position:relative;z-index:2;min-height:100vh;min-height:100dvh}.opening-heart-gate{position:fixed;inset:0;z-index:20;display:grid;place-items:center;overflow:hidden;padding:28px;background:radial-gradient(circle at 48% 44%,#fffaf5ad,#fff7f08a 30%,#f6e2ccc2 76%),linear-gradient(136deg,#fffaf5bd,#eeb9b533)}.opening-heart-gate:before,.opening-heart-gate:after{position:absolute;inset:auto;pointer-events:none;content:""}.opening-heart-gate:before{left:50%;top:50%;width:min(760px,88vw);aspect-ratio:1;border-radius:999px;background:radial-gradient(circle at 50% 50%,rgba(255,250,245,.58),transparent 58%),radial-gradient(circle at 50% 50%,rgba(248,207,208,.28),transparent 68%);filter:blur(10px);transform:translate(-50%,-50%)}.opening-heart-gate:after{inset:0;background:repeating-linear-gradient(108deg,rgba(109,62,45,.04) 0,rgba(109,62,45,.04) 1px,transparent 1px,transparent 10px);opacity:.32;mix-blend-mode:multiply}.opening-heart-button{position:relative;z-index:2;display:grid;width:min(500px,72vw);aspect-ratio:1;place-items:center;padding:0;border:0;color:var(--paper-solid);background:transparent;cursor:pointer;transform:translateY(-3vh)}.opening-heart-button:focus-visible{outline:2px solid rgba(242,125,143,.66);outline-offset:10px}.opening-heart-button[aria-disabled=true]{pointer-events:none}.opening-heart-aura,.opening-heart-ripple{position:absolute;inset:0;border-radius:999px;pointer-events:none}.opening-heart-aura{background:radial-gradient(circle,rgba(255,250,245,.7),rgba(255,247,240,.26) 48%,transparent 72%),radial-gradient(circle,rgba(248,207,208,.22),transparent 64%);filter:blur(4px)}.opening-heart-ripple{border:1px solid rgba(255,250,245,.86);box-shadow:0 0 42px #f8cfd047;opacity:0}.opening-heart-svg{position:relative;display:grid;width:min(390px,60vw);aspect-ratio:1 / .9;place-items:center;filter:drop-shadow(0 28px 42px rgba(88,58,34,.2));transition:transform .24s ease,filter .24s ease}.opening-heart-button:hover .opening-heart-svg,.opening-heart-button:focus-visible .opening-heart-svg{filter:drop-shadow(0 32px 48px rgba(88,58,34,.23));transform:translateY(-2px) scale(1.02)}.opening-heart-art{position:relative;z-index:1;display:block;width:100%;height:100%;overflow:visible}.opening-heart-art path{vector-effect:non-scaling-stroke}.opening-heart-shadow{fill:#b65f4a1f;transform:translateY(3px)}.opening-heart-fill{fill:url(#opening-heart-fill);stroke:#fffaf5b8;stroke-width:1.5}.opening-heart-glow{fill:url(#opening-heart-glow);opacity:.9}.petal-field{position:fixed;inset:0;z-index:1;pointer-events:none;overflow:hidden}.petal{position:absolute;top:-24px;display:block;border-radius:80% 20%;background:#f27d8f94;transform:rotate(18deg);animation:petal-fall linear infinite}@keyframes petal-fall{0%{opacity:0;transform:translate3d(0,-40px,0) rotate(0)}12%{opacity:.8}to{opacity:0;transform:translate3d(72px,108vh,0) rotate(260deg)}}.cursor-heart-layer{position:fixed;inset:0;z-index:30;pointer-events:none}.cursor-heart{position:absolute;color:#f27d8fa8;filter:drop-shadow(0 6px 10px rgba(182,95,74,.18));translate:-50% -50%;animation:cursor-heart-rise .98s ease-out forwards}@keyframes cursor-heart-rise{0%{opacity:0;transform:translate3d(0,6px,0) scale(.72) rotate(-8deg)}18%{opacity:.82}to{opacity:0;transform:translate3d(var(--cursor-heart-drift),-54px,0) scale(1.22) rotate(16deg)}}.home-hero{position:relative;z-index:2;display:grid;grid-template-columns:minmax(430px,1fr) minmax(540px,1fr);gap:clamp(22px,3.2vw,52px);width:min(1320px,calc(100% - 48px));min-height:100vh;margin:0 auto;padding:56px 0;align-items:center}.hero-copy{max-width:640px;padding-top:18px}.eyebrow{display:inline-flex;align-items:center;gap:8px;color:var(--rose-deep);font-size:.98rem;font-weight:700}.hero-copy h1{margin:14px 0 0;color:var(--leaf-dark);font-family:var(--font-display);font-size:clamp(3.2rem,5vw,4.6rem);font-weight:700;line-height:.98;letter-spacing:0;white-space:nowrap}.hero-subtitle{margin:24px 0 0;color:var(--bark);font-size:clamp(1.32rem,1.8vw,1.7rem);line-height:1.6}.hero-message{max-width:590px;margin:16px 0 0;color:#2f3a2fd1;font-size:clamp(1.06rem,1.2vw,1.18rem);line-height:1.9}.time-band{width:min(680px,100%);margin-top:34px;padding:22px;border:1px solid var(--line);border-radius:8px;background:#fffaf5b8;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.time-band-title{display:flex;align-items:center;gap:9px;color:var(--rose-deep);font-weight:700}.love-timer{display:grid;grid-template-columns:repeat(4,minmax(62px,1fr));gap:12px;margin-top:18px}.time-unit{display:grid;min-height:88px;place-items:center;border:1px solid rgba(123,143,90,.28);border-radius:8px;background:#fff7f0b3}.time-unit strong{color:var(--leaf-dark);font-family:var(--font-display);font-size:clamp(2.25rem,3vw,3.1rem);line-height:1}.time-unit small{color:#2f3a2fad;font-size:.86rem}.hero-story-side{position:relative;display:block}.home-hero.is-portrait{display:flex;flex-direction:column;grid-template-columns:none;width:min(100% - 32px,560px);min-height:auto;gap:26px;padding:calc(76px + env(safe-area-inset-top)) 0 calc(44px + env(safe-area-inset-bottom))}.home-hero.is-portrait .hero-copy{max-width:none;padding-top:0}.home-hero.is-portrait .hero-story-side{width:100%}.memory-list{display:flex;flex-direction:column;gap:12px;margin:0;padding:0;list-style:none}.memory-card{display:flex;align-items:center;gap:14px;padding:12px;border:1px solid var(--line);border-radius:14px;background:#fffaf5d1;box-shadow:0 12px 30px #583a221f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:transform .16s ease,box-shadow .16s ease}.memory-card:active{transform:scale(.99)}.memory-card:focus-visible{outline:2px solid rgba(242,125,143,.5);outline-offset:2px}.memory-card-thumb{display:grid;width:60px;height:60px;flex:0 0 auto;place-items:center;overflow:hidden;border-radius:12px;color:var(--paper-solid);background-position:center;background-size:cover}.memory-card-thumb.is-placeholder{background:radial-gradient(circle at 36% 30%,rgba(248,207,208,.7),transparent 60%),linear-gradient(135deg,#7b8f5ae6,#b65f4ac7)}.memory-card-body{display:flex;min-width:0;flex:1 1 auto;flex-direction:column;gap:4px}.memory-card-date{color:var(--rose-deep);font-size:.82rem;font-weight:700}.memory-card-title{overflow:hidden;color:var(--leaf-dark);font-size:1.06rem;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.memory-card-arrow{flex:0 0 auto;color:var(--rose-deep)}.hero-tree-stage{position:relative;min-height:min(700px,78vh);pointer-events:none}.heart-tree{position:absolute;right:-2vw;top:50%;width:min(850px,116%);height:min(660px,76vh);margin-left:auto;pointer-events:none;transform:translateY(-50%)}.memory-canopy{position:absolute;isolation:isolate}.canopy-hint{position:absolute;inset:4% 0 10% 4%;border-radius:54% 46% 44% 56%;background:radial-gradient(circle at 44% 34%,rgba(255,231,216,.28),transparent 28%),radial-gradient(circle at 70% 36%,rgba(242,125,143,.2),transparent 30%);filter:blur(10px);opacity:.62;pointer-events:none}.memory-leaf-wrap{position:absolute;left:var(--desktop-x);top:var(--desktop-y);z-index:2;translate:-50% -50%;pointer-events:auto}.memory-leaf{position:relative;display:inline-flex;align-items:center;gap:6px;max-width:148px;min-height:34px;padding:6px 10px 6px 7px;border:1px solid rgba(255,247,240,.72);border-radius:999px;color:#fffaf5;background:#7b8f5ae6;box-shadow:0 10px 24px #583a2238;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transform-origin:50% 70%;transition:transform .18s ease,background .18s ease,box-shadow .18s ease}.leaf-date{position:absolute;left:50%;bottom:calc(100% + 10px);z-index:5;display:block;min-width:max-content;padding:6px 9px;border:1px solid rgba(255,250,245,.68);border-radius:999px;color:var(--paper-solid);background:#6d3e2d9e;box-shadow:0 12px 28px #583a2233;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);font-size:.76rem;font-weight:700;opacity:0;pointer-events:none;transform:translate(-50%,6px);transition:opacity .18s ease,transform .18s ease}.leaf-date:after{position:absolute;left:50%;top:100%;width:8px;height:8px;content:"";background:#6d3e2d9e;transform:translate(-50%,-4px) rotate(45deg)}.memory-leaf:before{position:absolute;inset:-8px;z-index:-1;border-radius:999px;content:"";background:radial-gradient(circle,rgba(255,247,240,.35),transparent 66%);opacity:0;transition:opacity .18s ease}.leaf-shape{display:grid;width:25px;height:25px;flex:0 0 auto;place-items:center;border-radius:70% 30%;background:#fffaf52e;transform:rotate(-18deg)}.leaf-shape svg{transform:rotate(18deg)}.leaf-title{overflow:hidden;max-width:96px;font-size:.82rem;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.branch-upper .memory-leaf,.branch-right .memory-leaf{background:#b65f4ae6}.branch-center .memory-leaf{background:#f27d8fe6}.branch-lower .memory-leaf{background:#7d683ee6}.memory-leaf:hover,.memory-leaf:focus-visible{background:var(--rose-deep);box-shadow:0 16px 30px #583a2247;outline:none;transform:translateY(-4px) scale(1.05)}.memory-leaf:hover:before,.memory-leaf:focus-visible:before{opacity:1}.memory-leaf:hover .leaf-date,.memory-leaf:focus-visible .leaf-date{opacity:1;transform:translate(-50%)}.top-nav{position:relative;z-index:4;display:flex;justify-content:space-between;width:min(1120px,calc(100% - 40px));margin:0 auto;padding-top:22px}.icon-link{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:38px;padding:8px 12px;border:1px solid var(--line);border-radius:8px;color:var(--leaf-dark);background:#fffaf5bd;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);font-size:.95rem;font-weight:700;cursor:pointer}.icon-link:focus-visible,a:focus-visible{outline:2px solid rgba(242,125,143,.5);outline-offset:2px}.event-page{background:linear-gradient(180deg,#2f3a2f14,#2f3a2f33),url(/assets/garden-bg.jpg) center / cover no-repeat}.story-viewer{position:relative;z-index:2;display:grid;grid-template-columns:minmax(72px,1fr) minmax(0,1120px) minmax(72px,1fr);gap:clamp(10px,2vw,24px);min-height:100vh;align-items:center;padding:clamp(14px,2.4vw,28px);outline:none;touch-action:pan-x pan-y}.story-home-link{position:fixed;left:clamp(16px,2.6vw,34px);top:clamp(14px,2.4vw,30px);z-index:7;display:inline-flex;align-items:center;gap:8px;min-height:40px;padding:8px 12px;border:1px solid rgba(255,250,245,.58);border-radius:999px;color:var(--paper-solid);background:#2f3a2f5c;box-shadow:0 16px 38px #2f3a2f33;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);font-size:.92rem;font-weight:700}.story-frame{position:relative;grid-column:2;width:min(1120px,100%);height:min(860px,calc(100vh - 44px));min-height:620px;overflow:hidden;border:1px solid rgba(255,250,245,.52);border-radius:8px;background:#f6e2cc7a;box-shadow:0 34px 90px #2f3a2f52;isolation:isolate}.story-event-stage{position:absolute;inset:0;z-index:1;overflow:hidden}.story-backdrop{position:absolute;inset:0;z-index:0;background-position:center;background-size:cover}.story-backdrop.is-placeholder{background:radial-gradient(circle at 34% 22%,rgba(248,207,208,.66),transparent 27%),radial-gradient(circle at 76% 30%,rgba(123,143,90,.28),transparent 32%),linear-gradient(135deg,#fff7f0db,#f6e2ccb8),url(/assets/garden-bg.jpg) center / cover no-repeat;filter:saturate(.92)}.story-shade{position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(180deg,#2f3a2f47,#2f3a2f05 34%,#2f3a2fc2),radial-gradient(circle at 50% 68%,transparent,rgba(47,58,47,.18) 74%)}.story-topline{position:absolute;left:clamp(18px,3vw,38px);right:clamp(18px,3vw,38px);top:clamp(18px,3vw,36px);z-index:2;display:flex;align-items:flex-start;justify-content:space-between;gap:14px;color:var(--paper-solid);text-shadow:0 2px 16px rgba(47,58,47,.34)}.story-topline-left{display:flex;flex-direction:column;align-items:flex-start;gap:10px;min-width:0;max-width:min(64%,520px)}.story-date,.story-count{display:inline-flex;align-items:center;gap:8px;min-height:34px;padding:7px 10px;border:1px solid rgba(255,250,245,.44);border-radius:999px;background:#2f3a2f3d;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);font-size:.9rem;font-weight:700}.story-photo-name{max-width:100%;margin:0;padding:6px 14px;border:1px solid rgba(255,250,245,.4);border-radius:14px;color:var(--paper-solid);font-family:var(--font-body);font-weight:600;line-height:1.4;letter-spacing:.02em;background:linear-gradient(135deg,#2f3a2f75,#6d3e2d52);box-shadow:0 14px 38px #2f3a2f3d;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);overflow-wrap:anywhere;text-shadow:0 2px 12px rgba(47,58,47,.34)}.story-caption{position:absolute;left:50%;bottom:clamp(18px,3vw,36px);z-index:2;width:min(900px,calc(100% - 76px));max-width:none;padding:clamp(18px,2.8vw,30px);border:1px solid rgba(255,250,245,.58);border-radius:8px;color:var(--paper-solid);background:linear-gradient(135deg,#2f3a2fa3,#6d3e2d6b),#2f3a2f6b;box-shadow:0 24px 70px #2f3a2f4d;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);transform:translate(-50%)}.story-caption h1{margin:0;font-family:var(--font-display);font-size:clamp(3rem,6vw,6.4rem);font-weight:700;line-height:.92;letter-spacing:0}.story-note{max-height:min(28vh,260px);margin-top:16px;overflow-y:auto;color:#fffaf5e0;font-size:clamp(1.04rem,1.28vw,1.18rem);line-height:1.82}.story-note p{margin:0 0 10px}.story-side-arrow{position:relative;z-index:4;display:grid;width:clamp(68px,7vw,104px);height:clamp(104px,18vh,184px);place-items:center;border:1px solid rgba(255,250,245,.38);border-radius:999px;color:#fffaf5e0;background:#2f3a2f33;box-shadow:0 20px 52px #2f3a2f2e;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);cursor:pointer;opacity:.78;transition:opacity .18s ease,color .18s ease,background .18s ease,transform .18s ease}.story-side-arrow:before{position:absolute;inset:-14px;z-index:-1;border-radius:inherit;content:"";background:radial-gradient(circle,rgba(255,250,245,.22),transparent 66%);opacity:.38;transition:opacity .18s ease}.story-side-arrow-left{grid-column:1;justify-self:end}.story-side-arrow-left:before{transform:translate(8px)}.story-side-arrow-right{grid-column:3;justify-self:start}.story-side-arrow-right:before{transform:translate(-8px)}.story-side-arrow svg{position:relative;width:clamp(44px,4.6vw,72px);height:clamp(44px,4.6vw,72px);stroke-width:1.25;filter:drop-shadow(0 10px 22px rgba(47,58,47,.32))}.story-side-arrow:hover,.story-side-arrow:focus-visible{color:var(--paper-solid);background:#6d3e2d42;opacity:1;outline:none;transform:scale(1.04)}.story-side-arrow:hover:before,.story-side-arrow:focus-visible:before{opacity:1}.story-side-arrow:disabled{cursor:default;opacity:0;pointer-events:none}.story-event-dots{position:absolute;left:50%;bottom:12px;z-index:5;display:flex;align-items:center;justify-content:center;gap:9px;padding:8px 10px;border:1px solid rgba(255,250,245,.22);border-radius:999px;background:#2f3a2f47;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);transform:translate(-50%)}.story-event-dots button{display:block;width:8px;height:8px;padding:0;border:0;border-radius:999px;background:#fffaf56b;cursor:pointer;transition:width .22s ease,background .22s ease,box-shadow .22s ease}.story-event-dots button[aria-current=true]{width:28px;background:linear-gradient(90deg,#f27d8feb,#fffaf5e0);box-shadow:0 0 18px #f27d8f4d}.story-event-dots button:focus-visible{outline:2px solid rgba(255,250,245,.6);outline-offset:3px}.story-event-dots span{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}.empty-gallery,.loading-state{display:grid;min-height:220px;place-items:center;border:1px solid var(--line);border-radius:8px;color:var(--rose-deep);background:#fffaf5b8}.loading-state{position:relative;z-index:2;width:min(640px,calc(100% - 40px));margin:26vh auto 0}.empty-gallery{gap:6px;margin-top:18px}.empty-gallery p{margin:0;font-weight:700}@media(max-width:1040px){.home-hero{grid-template-columns:1fr;padding-top:84px}.hero-copy{max-width:720px}.hero-tree-stage{min-height:420px}.heart-tree{right:0;top:0;width:min(720px,100%);height:420px;margin:0 auto;transform:none}}@media(max-width:720px){.opening-heart-gate{padding:20px}.opening-heart-button{width:min(430px,86vw);transform:translateY(-7vh)}.opening-heart-svg{width:min(340px,82vw)}.home-hero{width:min(100% - 28px,560px);gap:20px;min-height:auto;padding:82px 0 78px}.hero-copy h1{font-size:clamp(2rem,11vw,3.6rem)}.hero-subtitle{font-size:1.1rem}.time-band{padding:16px}.love-timer{grid-template-columns:repeat(2,minmax(0,1fr))}.heart-tree{position:relative;right:auto;top:auto;width:100%;min-width:0;height:360px;margin-top:-16px;transform:none}.memory-leaf-wrap{left:var(--mobile-x);top:var(--mobile-y)}.memory-leaf{max-width:118px;min-height:36px;padding:6px 9px 6px 7px}.leaf-title{max-width:68px;font-size:.78rem}.top-nav{width:min(100% - 28px,560px)}.story-viewer{grid-template-columns:42px minmax(0,1fr) 42px;gap:4px;min-height:100dvh;padding:10px}.story-home-link{left:calc(14px + env(safe-area-inset-left));top:calc(14px + env(safe-area-inset-top));min-height:36px;padding:7px 10px}.story-frame{grid-column:1 / -1;width:100%;height:calc(100dvh - 20px);min-height:560px}.story-topline{align-items:flex-start;flex-direction:column;gap:8px;top:68px}.story-date,.story-count{max-width:100%;font-size:.8rem}.story-caption{width:calc(100% - 32px);bottom:calc(74px + env(safe-area-inset-bottom));padding:16px}.story-caption h1{font-size:clamp(2.5rem,13vw,3.8rem)}.story-note{max-height:22vh;font-size:.98rem}.story-side-arrow{position:absolute;top:50%;width:42px;height:96px;border-color:#fffaf547;background:#2f3a2f2e;transform:translateY(-50%)}.story-side-arrow:hover,.story-side-arrow:focus-visible{transform:translateY(-50%) scale(1.03)}.story-side-arrow-left{left:12px}.story-side-arrow-right{right:12px}.story-side-arrow svg{width:34px;height:34px}.story-event-dots{bottom:calc(16px + env(safe-area-inset-bottom))}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}
