*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow-x:hidden}body{background-color:#faf7f2;font-family:Cormorant Garamond,serif;color:#3d2b0a}#root{min-height:100vh}.particles-container{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}.particle{position:absolute;bottom:-20px;font-family:serif;animation:floatUp linear infinite;will-change:transform,opacity}@keyframes floatUp{0%{transform:translateY(0) rotate(0);opacity:0}10%{opacity:1}85%{opacity:.5}to{transform:translateY(-110vh) rotate(360deg);opacity:0}}.envelope-wrap{position:relative;width:300px;height:210px;perspective:800px}.envelope-body{position:absolute;inset:0;background:linear-gradient(145deg,#faf7f2,#f0e8d0);border:1px solid rgba(201,168,76,.35);border-radius:2px;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 40px #c9a84c33,0 2px 10px #00000014}.envelope-seal{font-size:2.8rem;color:#c9a84c;animation:pulse 1.2s ease infinite}.envelope-flap{position:absolute;top:0;left:0;width:100%;height:55%;background:linear-gradient(160deg,#f5edd8,#faf7f2);border:1px solid rgba(201,168,76,.3);clip-path:polygon(0 0,100% 0,50% 100%);transform-origin:top center;transition:transform 1.4s cubic-bezier(.4,0,.2,1);z-index:2}.envelope-wrap.opening .envelope-flap{transform:rotateX(-175deg)}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.12)}}.letter-container{display:flex;align-items:flex-start;justify-content:center;min-height:100vh;padding:3rem 1.5rem;z-index:10;position:relative;animation:fadeIn .8s ease both}.letter-paper{background:#fff;max-width:680px;width:100%;padding:clamp(2rem,6vw,4rem) clamp(2rem,7vw,5rem);box-shadow:0 2px 4px #0000000a,0 8px 32px #c9a84c1f,0 32px 64px #0000000f;border:1px solid rgba(201,168,76,.2);position:relative}.letter-paper:before,.letter-paper:after{content:"";position:absolute;width:18px;height:18px;border-color:#c9a84c80;border-style:solid}.letter-paper:before{top:14px;left:14px;border-width:1px 0 0 1px}.letter-paper:after{bottom:14px;right:14px;border-width:0 1px 1px 0}.letter-header{text-align:center;margin-bottom:2.5rem}.letter-ornament{font-size:.7rem;letter-spacing:.4em;color:#e8c97a;margin-bottom:.75rem;animation:fadeIn 1s ease .3s both}.letter-date{font-family:Cormorant Garamond,serif;font-size:.85rem;font-weight:300;letter-spacing:.28em;text-transform:uppercase;color:#c9a84c;margin-bottom:1.5rem;animation:fadeIn 1s ease .5s both}.letter-divider{height:1px;background:linear-gradient(to right,transparent,#E8C97A,transparent);animation:expandWidth .9s ease both}@keyframes expandWidth{0%{transform:scaleX(0);opacity:0}to{transform:scaleX(1);opacity:1}}.letter-body{font-family:Cormorant Garamond,serif;line-height:1.9}.letter-line{animation:fadeInUp .65s ease both;margin-bottom:1.2rem}.letter-salutation{font-size:1.35rem;font-weight:500;color:#c9a84c;font-style:italic;margin-bottom:1.8rem!important}.letter-paragraph{font-size:1.15rem;font-weight:300;color:#3d2b0a;text-align:justify}.letter-prayer{font-size:1.15rem;font-weight:300;font-style:italic;color:#5a4010;text-align:justify;border-left:2px solid rgba(201,168,76,.4);padding-left:1rem;margin-top:.5rem}.highlight{background:linear-gradient(120deg,#c9a84c2e,#e8c97a59,#c9a84c2e);color:#8a5e00;font-weight:600;font-style:normal;padding:.05em .25em;border-radius:2px;border-bottom:1px solid rgba(201,168,76,.5)}.letter-verse{font-size:1rem;font-weight:300;font-style:italic;color:#7a5c2a;text-align:center;margin-top:.8rem;padding:.9rem 1.2rem;border-top:1px solid rgba(201,168,76,.25);border-bottom:1px solid rgba(201,168,76,.25);line-height:1.7}.letter-verse .highlight{display:block;font-style:normal;font-weight:500;font-size:.85rem;letter-spacing:.05em;background:none;border-bottom:none;color:#c9a84c;margin-top:.4rem;padding:0}.letter-closing{font-size:1.1rem;font-weight:300;font-style:italic;color:#7a5c2a;margin-top:1.8rem!important}.letter-signature{font-family:Playfair Display,serif;font-size:1.25rem;font-style:italic;color:#c9a84c;margin-bottom:.3rem!important}.letter-name{font-family:Playfair Display,serif;font-size:1.05rem;font-weight:700;letter-spacing:.06em;color:#3d2b0a;margin-bottom:0!important}.letter-footer{margin-top:2.5rem;text-align:center;animation:fadeIn 1s ease both}.letter-heart{font-size:2rem;color:#c9a84c;margin-top:1.2rem;display:inline-block;animation:heartbeat 1.6s ease infinite}@keyframes heartbeat{0%,to{transform:scale(1)}14%{transform:scale(1.18)}28%{transform:scale(1)}42%{transform:scale(1.1)}56%{transform:scale(1)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.gate-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;z-index:10;position:relative;animation:fadeIn .8s ease both}.gate-box{text-align:center;padding:3rem 2.5rem;background:#fff;border:1px solid rgba(201,168,76,.2);box-shadow:0 8px 32px #c9a84c1a,0 2px 8px #0000000d;max-width:400px;width:90%;position:relative}.gate-box:before,.gate-box:after{content:"";position:absolute;width:16px;height:16px;border-color:#c9a84c66;border-style:solid}.gate-box:before{top:10px;left:10px;border-width:1px 0 0 1px}.gate-box:after{bottom:10px;right:10px;border-width:0 1px 1px 0}.gate-icon{font-size:2rem;margin-bottom:1rem;animation:pulse 2s ease infinite}.gate-title{font-family:Playfair Display,serif;font-size:1.5rem;font-weight:400;color:#3d2b0a;margin-bottom:.5rem}.gate-subtitle{font-family:Cormorant Garamond,serif;font-size:1rem;font-weight:300;font-style:italic;color:#7a5c2a;margin-bottom:2rem}.gate-inputs{display:flex;gap:.6rem;justify-content:center;margin-bottom:1rem}.gate-digit{width:44px;height:52px;text-align:center;font-family:Playfair Display,serif;font-size:1.4rem;color:#3d2b0a;background:#faf7f2;border:1px solid rgba(201,168,76,.35);border-radius:2px;outline:none;transition:border-color .2s ease,box-shadow .2s ease;caret-color:#c9a84c}.gate-digit:focus{border-color:#c9a84c;box-shadow:0 0 0 2px #c9a84c26;background:#fff}.gate-digit.filled{border-color:#c9a84c99}.gate-digit.error{border-color:#c0392b;background:#fff5f5}.gate-error{font-family:Cormorant Garamond,serif;font-size:.9rem;font-style:italic;color:#c0392b;animation:fadeIn .3s ease both}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}.shake{animation:shake .6s ease both}.app{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;background:linear-gradient(135deg,#faf7f2,#f5edd8,#faf7f2)}.intro-screen{text-align:center;animation:fadeIn 1.2s ease both;z-index:10;padding:2rem}.intro-date{font-family:Cormorant Garamond,serif;font-size:.9rem;font-weight:300;letter-spacing:.35em;text-transform:uppercase;color:#c9a84c;margin-bottom:1.5rem;opacity:0;animation:fadeIn 1s ease .4s both}.intro-title{font-family:Playfair Display,serif;font-size:clamp(2.5rem,8vw,5rem);font-weight:400;line-height:1.2;color:#3d2b0a;margin-bottom:1rem;opacity:0;animation:fadeInUp 1s ease .7s both}.intro-title em{font-style:italic;color:#c9a84c}.intro-subtitle{font-family:Cormorant Garamond,serif;font-size:1.2rem;font-weight:300;font-style:italic;color:#7a5c2a;margin-bottom:3rem;opacity:0;animation:fadeIn 1s ease 1.1s both}.open-btn{position:relative;background:transparent;border:1px solid #C9A84C;color:#c9a84c;font-family:Cormorant Garamond,serif;font-size:1rem;font-weight:400;letter-spacing:.2em;text-transform:uppercase;padding:1rem 3rem;cursor:pointer;overflow:hidden;transition:color .4s ease;opacity:0;animation:fadeIn 1s ease 1.5s both}.open-btn:before{content:"";position:absolute;inset:0;background:#c9a84c;transform:scaleX(0);transform-origin:left;transition:transform .4s ease;z-index:-1}.open-btn:hover{color:#faf7f2}.open-btn:hover:before{transform:scaleX(1)}.opening-screen{display:flex;align-items:center;justify-content:center;animation:fadeIn .5s ease both;z-index:10}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
