.landing-page{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:80vh;display:flex}.landing-page h1{font-size:clamp(1.5rem,6vw,2.5rem)}.landing-page form{flex-wrap:wrap;justify-content:center;gap:.5rem;margin-top:1rem;display:flex}.landing-page input{border:2px solid var(--palette-light);border-radius:8px;outline:none;padding:.6rem 1rem;font-size:1rem}.landing-page input:focus{border-color:var(--palette-primary)}.landing-page button{background:var(--palette-primary);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.6rem 1.5rem;font-size:1rem}.landing-page button:hover{background:var(--palette-hover)}.error{color:#c0392b;min-height:1rem}.nav-bar{z-index:51;flex-wrap:wrap;justify-content:center;align-items:center;gap:1.5rem;margin-bottom:1.5rem;padding:.75rem 0;display:flex;position:relative}.nav-links{flex-wrap:wrap;justify-content:center;gap:1.5rem;display:flex}.burger{cursor:pointer;z-index:51;background:0 0;border:none;flex-direction:column;justify-content:space-between;width:24px;height:18px;padding:0;display:none;position:absolute;top:50%;right:0;transform:translateY(-50%)}.burger span{transform-origin:50%;background:#888;border-radius:2px;width:100%;height:2px;transition:background .2s,transform .25s,opacity .2s;display:block}.burger--open span:first-child{background:#888;transform:translateY(8px)rotate(45deg)}.burger--open span:nth-child(2){opacity:0}.burger--open span:nth-child(3){background:#888;transform:translateY(-8px)rotate(-45deg)}.mobile-menu{background:var(--palette-overlay,#28286459);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:50;flex-direction:column;justify-content:flex-end;align-items:flex-end;gap:.1rem;padding:3rem 2rem 4rem;animation:.3s forwards menu-fade-in;display:flex;position:fixed;inset:0}@keyframes menu-fade-in{0%{opacity:0}to{opacity:1}}@keyframes menu-fade-out{0%{opacity:1}to{opacity:0}}.mobile-menu--closing{animation:.28s forwards menu-fade-out}.mobile-menu a{letter-spacing:.02em;padding:.3rem 0;font-family:Poppins,system-ui,sans-serif;font-size:1.6rem;font-weight:600;text-decoration:none;transition:color .2s;position:relative;color:#fff!important}.mobile-menu a:after{content:"";transform-origin:100%;background:#fff;width:100%;height:1px;transition:transform .25s;position:absolute;bottom:0;left:0;transform:scaleX(0)}.mobile-menu a:hover{color:#fff}.mobile-menu a:hover:after{transform-origin:0;transform:scaleX(1)}.mobile-menu a.active{color:#fff}@media (width<=600px){.nav-links{display:none}.burger{display:flex}}.nav-bar a{color:#888;border-radius:6px;padding:.4rem .3rem;text-decoration:none;transition:color .2s;position:relative}.nav-bar a:after{content:"";background:var(--palette-primary);transform-origin:100%;width:100%;height:2px;transition:transform .25s;position:absolute;bottom:0;left:0;transform:scaleX(0)}.nav-bar .mobile-menu a:after{background:#fff;height:1px}.nav-bar a:hover{color:var(--palette-primary);font-size:1rem;font-weight:500}.nav-bar a:hover:after{transform-origin:0;transform:scaleX(1)}.nav-bar a.active{color:var(--palette-primary);font-size:1.125rem;font-weight:500}.page{padding:1rem 0}.page h2{text-align:center;margin-bottom:.25rem;font-size:clamp(1rem,3.5vw,1.4rem)}.hero-section{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:2.5rem;min-height:85vh;display:flex;position:relative}.hero-name{color:var(--palette-dark);letter-spacing:.03em;will-change:transform;font-family:Poppins,system-ui,sans-serif;font-size:clamp(3.5rem,14vw,7rem);font-weight:700;line-height:1;animation:2.5s ease-in-out 2.1s infinite alternate hero-float}@keyframes hero-float{0%{transform:translateY(0)}to{transform:translateY(-10px)}}.love-button{will-change:transform, opacity;color:var(--palette-primary);border:2px solid var(--palette-primary);cursor:pointer;will-change:transform;background:0 0;border-radius:50px;padding:.85rem 2.5rem;font-size:1.15rem;transition:color .2s,border-color .2s,transform .15s}.love-button:hover{color:var(--palette-hover);border-color:var(--palette-hover);transform:scale(1.05)}.scroll-indicator{color:var(--palette-primary);opacity:.5;animation:1.8s ease-in-out infinite scroll-bounce;position:absolute;bottom:2rem}@keyframes scroll-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(8px)}}.letter-overlay{background:var(--palette-overlay);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:100;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.letter-card{background:var(--palette-card-bg);border:1px solid var(--palette-vlight);width:100%;max-width:560px;max-height:80vh;box-shadow:0 20px 60px var(--palette-shadow);border-radius:16px;padding:2.5rem 2.5rem 2rem;position:relative;overflow-y:auto}.letter-close{color:var(--palette-dark);cursor:pointer;opacity:.55;background:0 0;border:none;padding:0;font-size:1.8rem;line-height:1;transition:opacity .15s;position:absolute;top:1rem;right:1.2rem}.letter-close:hover{opacity:1}.letter-body{color:#444;flex-direction:column;gap:1.1rem;font-size:1rem;line-height:1.8;display:flex}.letter-body p:first-child{color:#333;font-size:1.05rem;font-weight:600}.letter-body p:last-child{color:var(--palette-dark);margin-top:.4rem;font-style:italic}.timeline-section{padding:5rem 0 3rem}.section-title{color:var(--palette-dark);text-align:center;letter-spacing:.02em;margin-bottom:3rem;font-family:Poppins,system-ui,sans-serif;font-size:clamp(1.4rem,5vw,2rem)}.timeline{border-left:2px solid var(--palette-vlight);flex-direction:column;gap:2.5rem;max-width:580px;margin:0 auto;padding-left:1.5rem;display:flex;position:relative}.timeline-item{padding-left:1.5rem;position:relative}.timeline-dot{background:var(--palette-primary);border:2px solid var(--palette-bg);width:10px;height:10px;box-shadow:0 0 0 2px var(--palette-primary);border-radius:50%;position:absolute;top:50%;left:-1.9rem;transform:translateY(-50%)}.timeline-date{text-transform:uppercase;letter-spacing:.1em;color:var(--palette-dark);opacity:.7;margin-bottom:.3rem;font-size:.75rem;display:block}.timeline-title{color:#333;margin-bottom:.45rem;font-size:1.1rem;font-weight:600}.timeline-desc{color:#666;font-size:.95rem;line-height:1.65}.timeline-clock{font-variant-numeric:tabular-nums;opacity:.75}.ending-section{text-align:center;padding:6rem 0 5rem}.ending-text{color:var(--palette-dark);letter-spacing:.03em;font-family:Poppins,system-ui,sans-serif;font-size:clamp(1.2rem,4vw,1.8rem);font-style:italic}.login-loading{background:var(--palette-bg,#f5f5ff);z-index:200;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.loading-message{color:var(--palette-dark,#7070cc);letter-spacing:.04em;text-align:center;will-change:opacity, transform;padding:0 2rem;font-family:Inter,system-ui,sans-serif;font-size:clamp(1.3rem,4vw,2rem);transition:opacity .6s,transform .6s}.loading-message--in{opacity:0;animation:.6s 50ms both msg-in;transform:translateY(12px)}.loading-message--hold{opacity:1;transform:translateY(0)}.loading-message--out{opacity:1;animation:.6s forwards msg-out;transform:translateY(0)}@keyframes msg-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes msg-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-12px)}}.animated-title{color:var(--palette-dark);letter-spacing:.03em;font-family:Poppins,system-ui,sans-serif;font-size:clamp(3.5rem,14vw,6rem);font-weight:700;line-height:1}.animated-title__letter{will-change:transform, opacity;animation:1.6s cubic-bezier(.215,.61,.355,1) both animated-title-fade-up;display:inline-block}@keyframes animated-title-fade-up{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{background:var(--palette-overlay);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:100;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.modal-card{background:var(--palette-card-bg);border:1px solid var(--palette-vlight);width:100%;max-width:560px;max-height:80vh;box-shadow:0 20px 60px var(--palette-shadow);border-radius:16px;padding:2.5rem 2.5rem 2rem;position:relative;overflow-y:auto}.modal-close{color:var(--palette-dark);cursor:pointer;opacity:.55;background:0 0;border:none;padding:0;font-size:1.8rem;line-height:1;transition:opacity .15s;position:absolute;top:1rem;right:1.2rem}.modal-close:hover{opacity:1}.moments-page{min-height:100vh;padding:3rem 1.5rem 6rem}.moments-title{text-align:center;margin-bottom:4rem}.photo-feed{flex-direction:column;gap:4rem;max-width:900px;margin:0 auto;display:flex}.photo-item{will-change:opacity, transform;flex-direction:column;width:60%;display:flex}.photo-item--left{align-self:flex-start;margin-left:2%}.photo-item--right{align-self:flex-end;margin-right:2%}.photo-item__img-wrap{aspect-ratio:4/3;background:var(--palette-vlight,#e8e8f0);border-radius:14px;overflow:hidden;box-shadow:0 6px 28px #0000001f}.photo-item__img-wrap img{object-fit:cover;pointer-events:none;width:100%;height:100%;display:block}.photo-item__placeholder{width:100%;height:100%;color:var(--palette-primary,#888);opacity:.7;justify-content:center;align-items:center;font-size:.95rem;font-style:italic;display:flex}.photo-item__caption{color:var(--palette-dark,#444);opacity:.8;margin-top:.7rem;padding:0 .25rem;font-size:.9rem;line-height:1.55}.photo-item--right .photo-item__caption{text-align:right}@media (width<=600px){.photo-item{width:100%;align-self:center!important;margin-left:0!important;margin-right:0!important}.photo-item--right .photo-item__caption{text-align:left}.photo-feed{gap:2.5rem}}.messages-page{min-height:100vh;padding:3rem 1.5rem 6rem}.messages-title{text-align:center;margin-bottom:4rem}.message-feed{flex-direction:column;gap:4rem;max-width:900px;margin:0 auto;display:flex}.message-item{will-change:opacity, transform;width:62%}.message-item--left{align-self:flex-start;margin-left:2%}.message-item--right{align-self:flex-end;margin-right:2%}.message-item__card{background:#faf7f2;border-radius:16px;padding:1.75rem 2rem;position:relative;box-shadow:0 6px 28px #00000017}.message-item__header{align-items:center;gap:.75rem;margin-bottom:.75rem;display:flex}.message-item__tag{letter-spacing:.08em;text-transform:uppercase;background:var(--palette-primary,#9b8fc4);color:#fff;border-radius:20px;padding:.2rem .65rem;font-size:.7rem;font-weight:700}.message-item__tag--note{background:var(--palette-accent,#b8aee0)}.message-item__date{color:var(--palette-dark,#666);opacity:.7;margin-bottom:1rem;font-size:.78rem;font-style:italic;display:flex}.message-item__title{color:var(--palette-dark,#333);margin:0 0 .9rem;font-size:1.1rem;font-weight:600}.message-item__body{color:var(--palette-dark,#444);white-space:pre-line;margin:0;font-size:.93rem;line-height:1.75}.message-item__from{color:var(--palette-primary,#9b8fc4);text-align:right;white-space:pre-line;margin-top:1rem;font-size:.88rem;font-style:italic}.message-item__read-more{color:var(--palette-primary,#9b8fc4);cursor:pointer;letter-spacing:.03em;background:0 0;border:none;margin-top:.85rem;padding:0;font-size:.85rem;font-weight:600;transition:opacity .15s}.message-item__read-more:hover{opacity:.7}.message-modal-content{flex-direction:column;gap:.5rem;display:flex}.message-modal-title{color:var(--palette-dark,#333);margin:.25rem 0 .75rem;font-size:1.15rem;font-weight:600}.message-modal-body{color:var(--palette-dark,#444);white-space:pre-line;margin:0;font-size:.97rem;line-height:1.8}@media (width<=600px){.message-item{width:100%;align-self:center!important;margin-left:0!important;margin-right:0!important}.message-item__card{padding:1.25rem}.message-feed{gap:2.5rem}}.dino-page{text-align:center;flex-direction:column;align-items:center;gap:1.25rem;min-height:80vh;padding:1.5rem 1rem 2.5rem;display:flex}.dino-title{color:var(--palette-dark);letter-spacing:.02em;font-size:clamp(2rem,6vw,3rem)}.dino-subtitle{color:var(--palette-primary);margin-top:-.5rem;font-size:1rem}.speech-bubble{background:var(--palette-card-bg,#fff);border:2px solid var(--palette-primary);text-align:left;width:100%;max-width:360px;box-shadow:0 4px 18px var(--palette-shadow,#2d6a4f2e);border-radius:18px;padding:1rem 2.5rem 1rem 1.25rem;position:relative}.speech-bubble:after{content:"";border:7px solid #0000;border-top-color:var(--palette-primary);position:absolute;bottom:-13px;left:50%;transform:translate(-50%)}.speech-bubble:before{content:"";border:5px solid #0000;border-top-color:var(--palette-card-bg,#fff);z-index:1;position:absolute;bottom:-8px;left:50%;transform:translate(-50%)}.speech-bubble p{color:#333;font-size:.95rem;line-height:1.65}.bubble-close{color:var(--palette-light);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.2rem .3rem;font-size:1rem;line-height:1;transition:color .15s;position:absolute;top:.45rem;right:.6rem}.bubble-close:hover{color:var(--palette-dark)}.dino-img{cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation;width:100%;max-width:380px;filter:drop-shadow(0 6px 14px var(--palette-shadow,#2d6a4f33));transition:filter .2s}.dino-img:hover{filter:drop-shadow(0 8px 20px var(--palette-shadow,#2d6a4f4d))}.dino-img:active{filter:drop-shadow(0 3px 8px var(--palette-shadow,#2d6a4f59))}.dino-hint{color:var(--palette-light);letter-spacing:.08em;font-size:.85rem}:root{color:#333;background-color:var(--palette-bg,#fff);font-family:Inter,system-ui,-apple-system,sans-serif}[data-theme=red]{--palette-primary:#d06070;--palette-dark:#c0485a;--palette-hover:#b84d5c;--palette-light:#e0a0a0;--palette-vlight:#f0d0d0;--palette-surface:#fde8e8;--palette-bg:#fff5f5;--palette-card-bg:#fff9f9;--palette-overlay:#50141e59;--palette-shadow:#a032462e}[data-theme=periwinkle]{--palette-primary:#b3b3ff;--palette-dark:#7070cc;--palette-hover:#9090e0;--palette-light:#ccf;--palette-vlight:#ddddf5;--palette-surface:#ededff;--palette-bg:#f5f5ff;--palette-card-bg:#f9f9ff;--palette-overlay:#28286459;--palette-shadow:#5050a02e}[data-theme=green]{--palette-primary:#52b788;--palette-dark:#2d6a4f;--palette-hover:#40916c;--palette-light:#95d5b2;--palette-vlight:#d8f3dc;--palette-surface:#e9f5ee;--palette-bg:#f0faf4;--palette-card-bg:#f8fdf9;--palette-overlay:#143c2859;--palette-shadow:#2d6a4f2e}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}h1,h2,h3,h4,h5,h6{font-family:Poppins,system-ui,-apple-system,sans-serif}body{justify-content:center;min-height:100vh;display:flex}#root{width:100%;max-width:900px;padding:2rem}@media (width<=600px){#root{padding:1rem}}
