@import"https://fonts.googleapis.com/css2?family=Dancing+Script:wght@400;700&family=Lora:ital,wght@0,400;0,600;1,400&family=Playfair+Display:ital,wght@0,400;0,700;1,400&display=swap";:root{--rose: #e8a0bf;--blush: #fcd5ce;--cream: #fef9ef;--deep-rose: #b5446e;--gold: #d4a574;--soft-pink: #f9e4ec;--dark-text: #4a2c3d;--light-text: #7d5068}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Lora,Georgia,serif;background-color:var(--cream);color:var(--dark-text);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%}h1,h2,h3{font-family:Playfair Display,Georgia,serif}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--cream)}::-webkit-scrollbar-thumb{background:var(--rose);border-radius:4px}.app{width:100%;min-height:100vh;position:relative;transition:background-color 1.2s ease}.app-locked{background-color:#0a0a0a}.app-unlocked{background-color:var(--cream)}.gate{position:fixed;inset:0;z-index:100;background:#0a0a0a;display:flex;align-items:center;justify-content:center}.gate-form{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:2rem}.gate-icon{font-size:3.5rem;color:#b5446e;text-shadow:0 0 30px rgba(181,68,110,.5)}.gate-prompt{font-family:Lora,Georgia,serif;font-size:1.1rem;color:#ffffff80;letter-spacing:1px}.gate-input-wrap{position:relative}.gate-input{background:transparent;border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:.9rem 1.5rem;font-size:1.2rem;color:#fff;text-align:center;letter-spacing:4px;width:260px;outline:none;font-family:Lora,Georgia,serif;transition:border-color .3s ease}.gate-input::placeholder{color:#fff3;letter-spacing:6px}.gate-input:focus{border-color:#b5446e;box-shadow:0 0 20px #b5446e33}.gate-button{background:transparent;border:1px solid rgba(181,68,110,.6);border-radius:30px;padding:.7rem 2.5rem;font-family:Lora,Georgia,serif;font-size:.95rem;color:#e8a0bf;cursor:pointer;letter-spacing:1px;transition:background .3s ease,color .3s ease}.gate-button:hover{background:#b5446e;color:#fff}.gate-hint{font-family:Dancing Script,cursive;font-size:1rem;color:#e8a0bf99;font-style:italic;margin-top:-.5rem}.gate-shake{animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}15%{transform:translate(-12px)}30%{transform:translate(10px)}45%{transform:translate(-8px)}60%{transform:translate(6px)}75%{transform:translate(-4px)}90%{transform:translate(2px)}}.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fef9ef,#fcd5ce,#f9e4ec 60%,#e8a0bf);position:relative;z-index:1}.hero-content{text-align:center;padding:2rem;width:100%;max-width:800px;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px}.hero-step{display:flex;flex-direction:column;align-items:center;gap:.5rem}.step-welcome{font-family:Dancing Script,cursive;font-size:clamp(2.5rem,8vw,4.5rem);font-weight:700;color:var(--deep-rose)}.step-label-since{font-family:Lora,Georgia,serif;font-style:italic;font-size:clamp(1.2rem,3vw,1.6rem);color:var(--light-text)}.step-date{font-family:Playfair Display,Georgia,serif;font-size:clamp(2rem,6vw,3.5rem);font-weight:700;color:var(--deep-rose);line-height:1.2}.step-number{font-family:Playfair Display,Georgia,serif;font-size:clamp(3.5rem,12vw,7rem);font-weight:700;color:var(--deep-rose);line-height:1}.step-label{font-family:Dancing Script,cursive;font-size:clamp(1.5rem,4vw,2.2rem);color:var(--gold);font-weight:700}.step-just{font-family:Lora,Georgia,serif;font-style:italic;font-size:clamp(1.1rem,3vw,1.5rem);color:var(--light-text)}.step-ily{font-family:Dancing Script,cursive;font-size:clamp(3rem,10vw,5.5rem);font-weight:700;color:var(--deep-rose);line-height:1.2;margin-top:.3rem}.hero-scroll{position:absolute;bottom:2rem}.scroll-arrow{font-size:1.5rem;color:var(--deep-rose);opacity:.6}.timeline-section{padding:6rem 2rem;background:var(--cream);position:relative;z-index:1}.section-title{text-align:center;font-size:clamp(1.8rem,5vw,3rem);color:var(--deep-rose);margin-bottom:4rem}.timeline{position:relative;max-width:900px;margin:0 auto;padding:2rem 0}.timeline-line{position:absolute;left:50%;top:0;bottom:0;width:3px;background:linear-gradient(to bottom,var(--blush),var(--rose),var(--deep-rose));transform:translate(-50%);border-radius:2px}.timeline-item{position:relative;width:50%;padding:0 3rem 3rem}.timeline-item.left{left:0;text-align:right}.timeline-item.right{left:50%;text-align:left}.timeline-marker{position:absolute;top:0;width:48px;height:48px;border-radius:50%;background:#fff;border:3px solid var(--rose);display:flex;align-items:center;justify-content:center;font-size:1.3rem;box-shadow:0 4px 15px #e8a0bf4d;z-index:2}.timeline-item.left .timeline-marker{right:-24px}.timeline-item.right .timeline-marker{left:-24px}.timeline-card{background:#fff;border-radius:16px;padding:1.8rem;box-shadow:0 4px 20px #b5446e14;border:1px solid rgba(232,160,191,.2);transition:transform .3s ease,box-shadow .3s ease}.timeline-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #b5446e26}.timeline-year{font-family:Dancing Script,cursive;font-size:1.5rem;font-weight:700;color:var(--gold)}.timeline-title{font-size:1.2rem;color:var(--deep-rose);margin:.5rem 0}.timeline-desc{font-size:.95rem;color:var(--light-text);line-height:1.6}@media(max-width:768px){.timeline-line{left:24px}.timeline-item{width:100%;padding:0 1rem 2.5rem 4rem;text-align:left}.timeline-item.left,.timeline-item.right{left:0;text-align:left}.timeline-item.left .timeline-marker,.timeline-item.right .timeline-marker{left:0;right:auto}}.gallery-section{padding:6rem 2rem;background:linear-gradient(180deg,var(--cream) 0%,var(--soft-pink) 100%);position:relative;z-index:1}.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:900px;margin:0 auto}.gallery-item{border-radius:16px;overflow:hidden;background:#fff;box-shadow:0 4px 20px #b5446e14;border:1px solid rgba(232,160,191,.2);transition:transform .3s ease,box-shadow .3s ease;cursor:pointer}.gallery-item:hover{transform:translateY(-6px) scale(1.02);box-shadow:0 12px 35px #b5446e2e}.gallery-image{width:100%;aspect-ratio:1;object-fit:cover;display:block}.gallery-placeholder{width:100%;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--blush),var(--soft-pink));gap:.5rem}.placeholder-icon{font-size:3rem}.placeholder-text{font-size:.85rem;color:var(--light-text);font-style:italic}.gallery-caption{padding:1rem;text-align:center;font-size:.9rem;color:var(--light-text);font-style:italic}@media(max-width:768px){.gallery-grid{grid-template-columns:repeat(2,1fr);gap:1rem}}@media(max-width:480px){.gallery-grid{grid-template-columns:1fr;max-width:320px}}.letter-section{padding:6rem 2rem;background:linear-gradient(180deg,var(--soft-pink) 0%,var(--cream) 100%);position:relative;z-index:1}.letter-container{max-width:650px;margin:0 auto}.letter-paper{background:#fff;border-radius:12px;padding:3rem 2.5rem;box-shadow:0 2px 10px #b5446e0f,0 10px 40px #b5446e1a;border:1px solid rgba(232,160,191,.15);position:relative}.letter-paper:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--rose),var(--deep-rose),var(--gold));border-radius:12px 12px 0 0}.letter-line{font-family:Dancing Script,cursive;font-size:clamp(1.2rem,3vw,1.5rem);line-height:1.8;color:var(--dark-text)}.letter-spacer{height:.8rem}@media(max-width:480px){.letter-paper{padding:2rem 1.5rem}}.footer{padding:4rem 2rem;text-align:center;background:linear-gradient(180deg,var(--cream) 0%,var(--blush) 100%);position:relative;z-index:1}.footer-heart{font-size:3rem;margin-bottom:1.5rem}.footer-text{font-family:Playfair Display,Georgia,serif;font-size:clamp(1.3rem,4vw,2rem);color:var(--deep-rose);margin-bottom:.5rem}.footer-subtext{font-family:Dancing Script,cursive;font-size:1.1rem;color:var(--light-text)}.footer-ps{margin-top:3rem;padding-top:2rem;border-top:1px solid rgba(232,160,191,.3);max-width:500px;margin-left:auto;margin-right:auto}.footer-ps-label{font-family:Playfair Display,Georgia,serif;font-weight:700;font-size:1.1rem;color:var(--deep-rose);margin-bottom:.8rem}.footer-ps-text{font-family:Lora,Georgia,serif;font-style:italic;font-size:.95rem;color:var(--light-text);line-height:1.8}.footer-ps-paw{display:block;margin-top:1rem;font-size:1.5rem}
