@import"https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@500;700&family=Work+Sans:wght@400;500;700&display=swap";.stf__parent{position:relative;display:block;box-sizing:border-box;transform:translateZ(0);-ms-touch-action:pan-y;touch-action:pan-y}.sft__wrapper{position:relative;width:100%;box-sizing:border-box}.stf__parent canvas{position:absolute;width:100%;height:100%;left:0;top:0}.stf__block{position:absolute;width:100%;height:100%;box-sizing:border-box;perspective:2000px}.stf__item{display:none;position:absolute;transform-style:preserve-3d}.stf__outerShadow,.stf__innerShadow,.stf__hardShadow,.stf__hardInnerShadow{position:absolute;left:0;top:0}:root{--bg: #f7efe9;--bg-accent: #ecd9cf;--ink: #37231c;--muted: #8c6b60;--dot: #6d4a42;--memory-dot: #d45054;--card: #fff8f2;--line: #d9b9ab}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;color:var(--ink);font-family:Work Sans,Segoe UI,sans-serif;background:radial-gradient(90rem 60rem at 10% -10%,#f5d8d5 0%,transparent 60%),radial-gradient(70rem 55rem at 95% 0%,#f1d8cc 0%,transparent 55%),linear-gradient(180deg,var(--bg),#f8f3ef)}.app-shell{max-width:1100px;margin:0 auto;padding:2rem 1rem 6rem}.gate-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.access-gate{width:min(460px,92vw);padding:clamp(1.25rem,3vw,2rem);border-radius:18px;border:1px solid rgba(217,185,171,.92);background:#fff8f2f2;box-shadow:0 18px 34px #47221c1f;text-align:center}.access-gate h2{margin:.45rem 0 .7rem;font-family:Cormorant Garamond,Georgia,serif;font-size:clamp(1.7rem,4vw,2.2rem);line-height:1.05}.access-gate p{margin:.4rem auto;color:var(--muted)}.access-gate-form{margin-top:1rem;display:grid;gap:.55rem}.access-gate-label{text-align:left;font-size:.8rem;color:var(--muted);letter-spacing:.04em;text-transform:uppercase}.access-gate-form input{width:100%;border:1px solid rgba(217,185,171,.95);border-radius:10px;background:#fffcf9f2;color:var(--ink);font:inherit;padding:.7rem .8rem}.access-gate-form input:focus-visible{outline:2px solid rgba(135,92,76,.4);outline-offset:1px}.access-gate-form button{border:1px solid rgba(217,185,171,.95);border-radius:999px;background:#5b372f;color:#fff5ef;font:inherit;font-size:.86rem;font-weight:600;padding:.58rem .96rem;cursor:pointer}.access-gate-error{margin-top:.7rem;font-size:.84rem;color:#b03c4f}.hero{margin-bottom:2rem;text-align:center}.hero-kicker{margin:0;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-size:.72rem}h1{margin:.4rem 0 .75rem;font-family:Cormorant Garamond,Georgia,serif;font-size:clamp(2.2rem,4.6vw,4rem);line-height:1}.hero p{margin:.3rem auto;max-width:56ch}.hero-stats{color:var(--muted)}.timeline-section{padding:1rem 0 0}.timeline-story{padding-top:.6rem}.timeline-canvas{position:relative;isolation:isolate;--scene-top: clamp(.4rem, 1.6vh, 1rem)}.story-grid-layer{position:sticky;top:var(--scene-top);min-height:100vh;display:flex;align-items:center;justify-content:center;z-index:2;pointer-events:none}.story-grid-frame{width:min(980px,93vw);height:min(76vh,760px);position:relative;overflow:visible}.memory-card{border-radius:14px;border:1px solid var(--line);background:#fff8f2;overflow:hidden;pointer-events:auto;will-change:transform,opacity}.memory-card img{width:100%;display:block;aspect-ratio:4 / 3;object-fit:contain;object-position:center;background:#f2e3db}.memory-card-text{padding:.55rem .65rem .65rem}.memory-card-text p{margin:.25rem 0 0;line-height:1.35}.active-memory-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:12}.memory-card-active{position:absolute;left:var(--active-start-left, 0px);top:var(--active-start-top, 0px);width:calc(var(--active-hero-width, 760px) - ((var(--active-hero-width, 760px) - var(--active-inline-width, 184px)) * var(--collapse-progress)));max-width:min(960px,93vw);border-radius:14px;background:#fff8f2;box-shadow:0 14px 26px #47221c24;transform-origin:top left;transform:translate(calc(var(--active-shift-x, 0px) * var(--collapse-progress)),calc(var(--active-shift-y, 0px) * var(--collapse-progress))) scale(calc(.96 + (var(--reveal-progress) * .04)));opacity:clamp(0,var(--reveal-progress),1);transition:transform 52ms linear,width 52ms linear}.memory-card-active img{border-radius:inherit}.memory-card-active .memory-card-text p{font-size:calc(.72rem + ((1 - var(--collapse-progress)) * .3rem));line-height:1.35}.memory-card-inline{position:absolute;left:50%;width:min(184px,68vw);transform:translate(-50%);box-shadow:0 14px 26px #47221c24;z-index:4;transition:opacity .1s linear}.memory-card-inline.is-above{bottom:calc(100% + 12px)}.memory-card-inline.is-below{top:calc(100% + 12px)}.memory-card-inline .memory-card-text p{font-size:.72rem;line-height:1.35}.story-progress-text{margin:0;width:fit-content;padding:.35rem .8rem;border-radius:999px;border:1px solid rgba(217,185,171,.8);background:#fff8f2db;box-shadow:0 8px 16px #47221c14;color:var(--muted);font-size:.79rem}.story-progress-pin{position:absolute;top:clamp(.35rem,1.2vh,.8rem);left:50%;transform:translate(-50%);z-index:8;pointer-events:none}.continuous-grid{width:100%;height:100%;display:grid;grid-template-columns:repeat(var(--story-columns, 12),minmax(0,1fr));grid-template-rows:repeat(var(--story-rows, 12),minmax(0,1fr));align-items:center;justify-items:center;position:relative;z-index:2}.story-day-cell{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:visible}.story-dot{width:var(--dot-size, 8px);height:var(--dot-size, 8px);border-radius:999px;background:radial-gradient(circle at 30% 25%,#b58f84,var(--dot));box-shadow:0 0 0 1px #00000014;opacity:0;transform:scale(.78);transition:opacity .22s ease,transform .22s ease}.story-dot.is-visible{background:radial-gradient(circle at 35% 25%,#f2b8a7,#8a5a4f 70%);opacity:1;transform:scale(1)}.story-dot-memory{width:calc(var(--dot-size, 8px) + 2px);height:calc(var(--dot-size, 8px) + 2px);background:radial-gradient(circle at 35% 25%,#f69a9f,var(--memory-dot));box-shadow:0 0 0 1px #6e2d2f4d,0 0 14px #d4505459}.story-dot.story-dot-memory.is-visible{background:radial-gradient(circle at 35% 25%,#ffb7c6,#de5f85 72%);box-shadow:0 0 0 1px #8a2e5061,0 0 16px #de5f856b}.timeline-grid-fallback{display:grid;grid-template-columns:repeat(auto-fill,minmax(12px,1fr));gap:10px 8px;padding:.8rem 0}.memory-date{font-size:.7rem;text-transform:uppercase;letter-spacing:.07em;color:var(--muted)}.app-footer{margin-top:1.5rem;text-align:center;color:var(--muted);font-size:.85rem}.photobook-section{margin-top:clamp(4rem,8vw,7rem)}.photobook-header{margin-bottom:.8rem;text-align:center}.photobook-header h2{margin:.35rem 0 0;font-family:Cormorant Garamond,Georgia,serif;font-size:clamp(1.7rem,3.3vw,2.6rem);line-height:1.1}.photobook-empty{margin:1rem 0 0;text-align:center;color:var(--muted)}.photobook-shell{display:grid;grid-template-columns:minmax(0,1fr);justify-items:center;gap:.9rem}.photobook-controls{display:flex;align-items:center;justify-content:center;gap:.6rem}.photobook-nav{border:1px solid rgba(217,185,171,.95);border-radius:999px;background:#fff8f2f2;color:var(--ink);font:inherit;font-size:.82rem;font-weight:600;padding:.55rem .9rem;cursor:pointer}.photobook-nav:disabled{opacity:.45;cursor:not-allowed}.photobook-book-wrap{width:min(92vw,1020px);border-radius:16px;padding:clamp(.35rem,1vw,.7rem);position:relative;background:linear-gradient(180deg,#fff8f2d1,#fff3eba6);border:1px solid rgba(217,185,171,.64);box-shadow:0 12px 24px #381f191a;outline:none}.photobook-book-wrap:focus-visible{box-shadow:0 12px 24px #381f191a,0 0 0 3px #875c4c5c}.photobook-flipbook{width:100%}.photobook-flipbook .stf__parent{margin:0 auto;filter:drop-shadow(0 12px 18px rgba(50,28,21,.12))}.photobook-flipbook .stf__wrapper{margin:0 auto}.photobook-page{position:relative;width:100%;height:100%;border-radius:2px;overflow:hidden;background:#fff9f4;border:1px solid rgba(176,132,116,.46);box-shadow:inset 0 0 0 1px #fffcf9b8,0 8px 16px #3a1e1814}.photobook-page-image{width:100%;height:100%;display:block;object-fit:cover}.photobook-page-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;justify-content:flex-end;padding:.75rem;background:linear-gradient(180deg,transparent 38%,rgba(27,16,12,.1) 68%,rgba(27,16,12,.68))}.photobook-meta{margin:0;color:#fff2ebe6;font-size:.66rem;text-transform:uppercase;letter-spacing:.09em}.photobook-caption{margin:.28rem 0 0;color:#fff7f1;font-size:clamp(.88rem,1.18vw,1rem);line-height:1.35}.photobook-caption-panel{width:min(700px,88vw);margin:.95rem auto 0;padding:.85rem .95rem 1rem;border-radius:14px;border:1px solid rgba(217,185,171,.78);background:#fff8f2e6;box-shadow:0 10px 18px #37231c14}.photobook-caption-panel .photobook-meta{color:var(--muted);font-size:.7rem;letter-spacing:.08em}.photobook-caption-panel .photobook-caption{color:var(--ink);font-size:clamp(.98rem,1.45vw,1.15rem);line-height:1.4;margin-top:.45rem}.photobook-progress{margin:.42rem 0 0;text-align:center;color:var(--muted);font-size:.8rem}.photobook-hint{margin:.12rem 0 0;text-align:center;color:var(--muted);font-size:.74rem}@media (max-width: 767px){.story-grid-frame{height:min(74vh,620px)}.story-progress-text{font-size:.74rem}.memory-card-inline{width:min(156px,72vw)}.photobook-shell{gap:.6rem;justify-items:center}.photobook-book-wrap{width:min(96vw,620px);padding:.3rem}.photobook-controls{width:100%;justify-content:center}.photobook-nav{justify-self:center}}
