@import "https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=Inter:wght@300;400;500;600&family=Dancing+Script:wght@600;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--rose:#e8628a;--rose-light:#f4a7bf;--rose-dark:#c0415f;--blush:#fdf0f4;--cream:#fffaf5;--gold:#d4a853;--gold-light:#f0d090;--text-dark:#2d1f27;--text-mid:#7a4f60;--text-light:#b08090;--dark-bg:#120609;--dark-bg2:#1f0d18}html{scroll-behavior:smooth}body{background:var(--cream);color:var(--text-dark);font-family:Inter,sans-serif;overflow-x:hidden}.gate{background:radial-gradient(at 30% 20%,#2a0d1c 0%,#130608 50%,#0d0408 100%);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex;position:relative;overflow:hidden}.gate-card{text-align:center;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:1;background:#ffffff0a;border:1px solid #e8628a33;border-radius:24px;width:100%;max-width:380px;padding:3rem 2.5rem;transition:transform .15s;position:relative}.gate-card.shake{animation:.5s shake}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}.gate-icon{width:52px;height:52px;color:var(--rose-light);background:#e8628a26;border:1px solid #e8628a4d;border-radius:14px;justify-content:center;align-items:center;margin:0 auto 1.5rem;display:flex}.gate-title{color:#fff;margin-bottom:.5rem;font-family:Dancing Script,cursive;font-size:2rem}.gate-sub{color:#ffffff59;letter-spacing:.05em;margin-bottom:2rem;font-size:.82rem}.gate-input{color:#fff;letter-spacing:.12em;text-align:center;background:#ffffff0f;border:1px solid #e8628a40;border-radius:12px;outline:none;width:100%;margin-bottom:1rem;padding:.85rem 1.1rem;font-family:Inter,sans-serif;font-size:1rem;transition:border-color .2s}.gate-input::placeholder{color:#fff3;letter-spacing:.05em}.gate-input:focus{border-color:#e8628a8c}.gate-btn{background:var(--rose);color:#fff;letter-spacing:.08em;cursor:pointer;border:none;border-radius:12px;width:100%;padding:.85rem;font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;transition:background .2s,transform .15s}.gate-btn:hover{background:var(--rose-dark)}.gate-btn:active{transform:scale(.98)}.hero{text-align:center;background:radial-gradient(at 30% 20%,#2a0d1c 0%,#130608 50%,#0d0408 100%);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex;position:relative;overflow:hidden}.hero-bg{pointer-events:none;position:absolute;inset:0}.floating-particle{opacity:0;-webkit-user-select:none;user-select:none;pointer-events:none;animation:linear infinite floatUp;position:absolute}@keyframes floatUp{0%{opacity:0;transform:translateY(110vh)rotate(0)}8%{opacity:var(--op,.6)}88%{opacity:calc(var(--op,.6) * .3)}to{opacity:0;transform:translateY(-15vh)rotate(180deg)}}.hero-pre{letter-spacing:.18em;text-transform:uppercase;color:#ffffff61;margin-bottom:.5rem;font-size:.78rem}.hero-badge{color:var(--rose-light);letter-spacing:.2em;text-transform:uppercase;background:#e8628a24;border:1px solid #e8628a59;border-radius:100px;align-items:center;gap:.4rem;margin-bottom:1.6rem;padding:.38rem 1.1rem;font-size:.72rem;display:inline-flex}.hero-title{color:#fff;text-shadow:0 0 80px #e8628a66;margin-bottom:.6rem;font-family:Dancing Script,cursive;font-size:clamp(3rem,9.5vw,7rem);line-height:1.1}.hero-title span{color:var(--rose-light);display:block}.hero-title.single-line{font-size:clamp(3.5rem,11vw,8rem)}.hero-subtitle{color:#ffffff73;max-width:500px;margin-bottom:.8rem;font-family:Playfair Display,serif;font-size:clamp(.9rem,2.2vw,1.25rem);font-style:italic}.hero-date{color:var(--gold-light);letter-spacing:.2em;opacity:.8;margin-bottom:4rem;font-size:.8rem}.scroll-cue{color:#ffffff4d;letter-spacing:.22em;text-transform:uppercase;flex-direction:column;align-items:center;gap:.45rem;font-size:.68rem;animation:2.2s ease-in-out infinite bob;display:flex;position:absolute;bottom:2rem;left:50%;transform:translate(-50%)}@keyframes bob{0%,to{transform:translate(-50%)translateY(0)}50%{transform:translate(-50%)translateY(7px)}}.stats-intro{text-align:center;color:#ffffff73;margin-bottom:2.5rem;font-family:Playfair Display,serif;font-size:1.1rem;font-style:italic}.stats-section{background:linear-gradient(180deg, #120609 0%, var(--blush) 32%);padding:5rem 2rem 4rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(148px,1fr));gap:1.1rem;max-width:860px;margin:0 auto;display:grid}.stat-card{text-align:center;background:#fff;border:1px solid #e8628a12;border-radius:18px;padding:1.7rem 1.2rem;transition:transform .25s,box-shadow .25s;box-shadow:0 6px 26px #e8628a17}.stat-card:hover{transform:translateY(-5px);box-shadow:0 14px 38px #e8628a2e}.stat-icon-wrap{background:var(--blush);width:42px;height:42px;color:var(--rose);border-radius:12px;justify-content:center;align-items:center;margin:0 auto .75rem;display:flex}.stat-number{color:var(--rose-dark);margin-bottom:.3rem;font-family:Playfair Display,serif;font-size:clamp(1.7rem,4vw,2.4rem);font-weight:700;line-height:1}.stat-label{color:var(--text-light);letter-spacing:.1em;text-transform:uppercase;font-size:.7rem}section{padding:5rem 2rem}.section-header{text-align:center;margin-bottom:3.5rem}.section-eyebrow{letter-spacing:.28em;text-transform:uppercase;color:var(--rose);margin-bottom:.55rem;font-size:.7rem}.section-title{color:var(--text-dark);font-family:Playfair Display,serif;font-size:clamp(1.8rem,4vw,2.8rem);line-height:1.2}.section-title em{color:var(--rose);font-style:italic}.section-sub{max-width:520px;color:var(--text-mid);margin:1rem auto 0;font-size:.95rem;line-height:1.8}.timeline-section{background:var(--blush)}.timeline{max-width:720px;margin:0 auto;position:relative}.timeline:before{content:"";background:linear-gradient(180deg, transparent, var(--rose-light) 10%, var(--rose) 50%, var(--rose-light) 90%, transparent);width:1px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.timeline-item{align-items:flex-start;gap:2rem;margin-bottom:2.8rem;display:flex;position:relative}.timeline-item:nth-child(odd){flex-direction:row}.timeline-item:nth-child(2n){flex-direction:row-reverse}.timeline-dot{border:2px solid var(--rose);z-index:1;width:24px;height:24px;color:var(--rose);background:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:1rem;display:flex;position:absolute;left:50%;transform:translate(-50%);box-shadow:0 0 0 4px #e8628a1f}.timeline-content{background:#fff;border-radius:16px;flex:1;max-width:calc(50% - 2.5rem);padding:1.4rem 1.5rem;box-shadow:0 4px 18px #0000000d}.timeline-icon-badge{background:var(--blush);width:32px;height:32px;color:var(--rose);border-radius:9px;justify-content:center;align-items:center;margin-bottom:.7rem;display:inline-flex}.timeline-date{color:var(--rose);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.35rem;font-size:.68rem;font-weight:600}.timeline-event{color:var(--text-dark);margin-bottom:.4rem;font-family:Playfair Display,serif;font-size:1rem;font-weight:700;line-height:1.3}.timeline-desc{color:var(--text-mid);font-size:.84rem;line-height:1.7}.gallery-section{background:var(--cream)}.gallery-grid{columns:3;column-gap:.75rem;max-width:1080px;margin:0 auto}.gallery-item{break-inside:avoid;cursor:pointer;border-radius:12px;margin-bottom:.75rem;transition:transform .25s,box-shadow .25s;position:relative;overflow:hidden;box-shadow:0 3px 12px #00000012}.gallery-item:hover{transform:scale(1.025);box-shadow:0 10px 30px #e8628a33}.gallery-item img{width:100%;display:block}.gallery-overlay{opacity:0;color:#fff;background:linear-gradient(#0000 45%,#c0415fa6 100%);align-items:flex-end;gap:.4rem;padding:.8rem;transition:opacity .25s;display:flex;position:absolute;inset:0}.gallery-item:hover .gallery-overlay{opacity:1}.gallery-overlay span{font-size:.72rem;font-weight:500}.lightbox{z-index:1000;cursor:pointer;background:#050204f0;justify-content:center;align-items:center;padding:2rem;animation:.18s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.lightbox img{object-fit:contain;cursor:default;border-radius:10px;max-width:90vw;max-height:85vh;box-shadow:0 0 80px #0009}.lightbox-close{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #ffffff26;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:background .2s;display:flex;position:absolute;top:1.5rem;right:1.5rem}.lightbox-close:hover{background:#fff3}.notices-section{background:var(--blush)}.notices-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;max-width:900px;margin:0 auto 3rem;display:grid}.notice-card{border-left:3px solid var(--rose-light);background:#fff;border-radius:14px;padding:1.4rem 1.6rem;position:relative;box-shadow:0 3px 16px #e8628a14}.notice-quote-icon{color:var(--rose-light);margin-bottom:.6rem}.notice-text{color:var(--text-dark);margin-bottom:.5rem;font-family:Playfair Display,serif;font-size:.95rem;font-style:italic;line-height:1.6}.notice-context{color:var(--rose);letter-spacing:.1em;text-transform:uppercase;font-size:.68rem;font-weight:600}.notices-note{background:linear-gradient(135deg, #fff 0%, var(--blush) 100%);border:1px solid #e8628a33;border-radius:18px;align-items:flex-start;gap:1.2rem;max-width:640px;margin:0 auto;padding:2rem 2.2rem;display:flex;box-shadow:0 6px 28px #e8628a1a}.notices-note-icon{background:var(--rose);color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;margin-top:2px;display:flex}.notices-note p{color:var(--text-mid);font-size:.95rem;line-height:1.85}.notices-note strong{color:var(--rose-dark)}.survived-section{text-align:center;background:radial-gradient(at 50% 0,#2a0d1c 0%,#0d0408 70%);position:relative;overflow:hidden}.survived-section:before{content:"♥";color:#e8628a08;pointer-events:none;font-size:30rem;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.survived-badge{color:var(--rose-light);letter-spacing:.16em;text-transform:uppercase;background:#e8628a1f;border:1px solid #e8628a47;border-radius:100px;align-items:center;gap:.5rem;margin-bottom:2rem;padding:.42rem 1.1rem;font-size:.7rem;display:inline-flex}.survived-title{color:#fff;margin-bottom:1.4rem;font-family:Playfair Display,serif;font-size:clamp(2rem,5vw,3.4rem);line-height:1.2}.survived-title em{color:var(--rose-light);font-style:italic}.survived-text{color:#ffffff80;max-width:520px;margin:0 auto 2.5rem;font-size:.97rem;line-height:1.9}.quotes-grid{text-align:left;grid-template-columns:repeat(auto-fit,minmax(255px,1fr));gap:1.1rem;max-width:860px;margin:0 auto;display:grid}.quote-card{background:#ffffff0a;border:1px solid #e8628a24;border-radius:14px;padding:1.4rem 1.6rem;position:relative}.quote-icon{color:var(--rose);opacity:.5;margin-bottom:.7rem;display:block}.quote-text{color:#ffffffd1;margin-bottom:.65rem;font-family:Playfair Display,serif;font-size:.92rem;font-style:italic;line-height:1.75}.quote-author{color:var(--rose-light);letter-spacing:.1em;text-transform:uppercase;font-size:.68rem}.letter-section{background:var(--blush);text-align:center}.letter-card{text-align:left;background:#fff;border:1px solid #e8628a17;border-radius:22px;max-width:640px;margin:0 auto;padding:clamp(2rem,5vw,3.5rem);position:relative;box-shadow:0 18px 55px #e8628a1a}.letter-book-icon{color:var(--rose-light);opacity:.5;position:absolute;top:1.8rem;right:1.8rem}.letter-greeting{color:var(--rose);margin-bottom:1.5rem;font-family:Dancing Script,cursive;font-size:1.9rem}.letter-body{color:var(--text-mid);font-size:.96rem;line-height:1.95}.letter-body p{margin-bottom:1.1rem}.letter-sign{color:var(--rose-dark);margin-top:1.8rem;font-family:Dancing Script,cursive;font-size:1.5rem;display:block}.footer{text-align:center;color:#ffffff38;background:#0d0408;padding:3rem 2rem;font-size:.8rem}.footer-heart{color:var(--rose);opacity:.8;margin:0 auto .8rem;animation:1.6s ease-in-out infinite heartbeat;display:block}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.footer-sub{opacity:.5;margin-top:.45rem}@media (width<=768px){.timeline:before{left:1.2rem}.timeline-item,.timeline-item:nth-child(2n){flex-direction:column;padding-left:3.2rem}.timeline-dot{left:1.2rem}.timeline-content{max-width:100%}.gallery-grid{columns:2}.notices-grid,.quotes-grid{grid-template-columns:1fr}.notices-note{text-align:center;flex-direction:column;align-items:center}}@media (width<=480px){.gallery-grid{columns:2;column-gap:.4rem}.gallery-item{margin-bottom:.4rem}.stats-grid{grid-template-columns:repeat(2,1fr)}.hero-subtitle{font-size:.88rem}}#root{width:100%;min-height:100vh}
