:root{--color-cream: #faf8f5;--color-warm-white: #f5f2ed;--color-blush: #e8d5d5;--color-rose: #d4a5a5;--color-dusty-rose: #c9b1b1;--color-deep-rose: #a67c7c;--color-charcoal: #3d3d3d;--color-soft-gray: #6b6b6b;--color-light-gray: #9a9a9a;--font-serif: "Cormorant Garamond", Georgia, serif;--font-handwritten: "Caveat", cursive;--font-sans: "Inter", -apple-system, sans-serif;--section-padding: 100vh}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;font-size:13px}body{font-family:var(--font-serif);background-color:var(--color-cream);color:var(--color-charcoal);line-height:1.8;overflow-x:hidden}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--color-warm-white)}::-webkit-scrollbar-thumb{background:var(--color-dusty-rose);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-rose)}::selection{background:var(--color-blush);color:var(--color-charcoal)}h1,h2,h3{font-family:var(--font-serif);font-weight:300;letter-spacing:.02em}p{font-size:1.25rem;line-height:2}.chapter{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:80px 24px;position:relative}.chapter-content{max-width:720px;width:100%;text-align:center}.chapter-title{font-size:clamp(2.5rem,8vw,4.5rem);margin-bottom:2rem;color:var(--color-charcoal);font-weight:300;font-style:italic}.chapter-text{font-size:clamp(1.1rem,3vw,1.35rem);color:var(--color-soft-gray);line-height:2.2;margin-bottom:1.5rem}.chapter-text em{font-style:italic;color:var(--color-deep-rose)}.poem{font-family:var(--font-handwritten);font-size:clamp(1.4rem,4vw,1.8rem);line-height:2;color:var(--color-deep-rose);padding:3rem 2rem;margin:3rem 0;position:relative;text-align:center}.poem:before,.poem:after{content:'"';font-family:var(--font-serif);font-size:4rem;color:var(--color-blush);position:absolute;opacity:.6}.poem:before{top:0;left:0}.poem:after{content:'"';bottom:0;right:0}.poem-line{display:block;margin-bottom:.5rem}.landing{background:linear-gradient(180deg,var(--color-warm-white) 0%,var(--color-cream) 100%)}.landing-title{font-size:clamp(2rem,6vw,3.5rem);font-weight:300;margin-bottom:1.5rem;letter-spacing:.05em}.landing-subtitle{font-size:clamp(1.2rem,3vw,1.5rem);color:var(--color-soft-gray);font-style:italic;margin-bottom:.5rem}.landing-note{font-family:var(--font-handwritten);font-size:clamp(1.3rem,3.5vw,1.6rem);color:var(--color-light-gray);margin-top:3rem;line-height:1.8}.cta-button{display:inline-block;margin-top:4rem;padding:1rem 2.5rem;font-family:var(--font-serif);font-size:1.1rem;font-style:italic;color:var(--color-charcoal);background:transparent;border:1px solid var(--color-dusty-rose);border-radius:50px;cursor:pointer;transition:all .4s ease;letter-spacing:.05em}.cta-button:hover{background:var(--color-blush);border-color:var(--color-blush);transform:translateY(-2px)}.divider{width:60px;height:1px;background:var(--color-dusty-rose);margin:2rem auto;opacity:.5}.chapter-1{background:var(--color-cream)}.chapter-2{background:linear-gradient(180deg,var(--color-cream) 0%,var(--color-warm-white) 50%,var(--color-cream) 100%)}.chapter-3{background:var(--color-cream)}.chapter-4{background:linear-gradient(180deg,var(--color-cream) 0%,#f7f3ef 50%,var(--color-cream) 100%)}.chapter-5{background:var(--color-cream)}.chapter-6{background:linear-gradient(180deg,var(--color-cream) 0%,var(--color-warm-white) 100%)}.chapter-7{background:linear-gradient(180deg,var(--color-warm-white) 0%,var(--color-blush) 100%)}.final-chapter{background:linear-gradient(180deg,var(--color-blush) 0%,var(--color-cream) 100%);padding-bottom:120px}.final-title{font-family:var(--font-handwritten);font-size:clamp(3rem,10vw,5rem);color:var(--color-deep-rose);margin-bottom:1rem}.final-subtitle{font-family:var(--font-serif);font-size:clamp(1.2rem,3vw,1.5rem);font-style:italic;color:var(--color-soft-gray)}.message-container{max-width:400px;margin:2rem auto;text-align:left}.message-bubble{background:var(--color-warm-white);padding:1rem 1.5rem;border-radius:20px 20px 20px 4px;font-family:var(--font-sans);font-size:1rem;color:var(--color-charcoal);box-shadow:0 2px 10px #0000000d;position:relative}.message-bubble.sent{background:var(--color-blush);border-radius:20px 20px 4px;margin-left:auto;text-align:right}.message-time{font-size:.75rem;color:var(--color-light-gray);margin-top:.5rem;font-family:var(--font-sans)}.love-list{list-style:none;text-align:left;max-width:500px;margin:2rem auto}.love-list li{font-size:clamp(1.1rem,2.5vw,1.25rem);color:var(--color-soft-gray);border-bottom:1px solid var(--color-blush);position:relative;padding:1rem 0 1rem 2rem}.love-list li:before{content:"♡";position:absolute;left:0;color:var(--color-rose)}.scroll-indicator{position:fixed;bottom:30px;left:50%;transform:translate(-50%);font-family:var(--font-sans);font-size:.75rem;color:var(--color-light-gray);letter-spacing:.2em;text-transform:uppercase;opacity:.6;transition:opacity .3s ease;z-index:100}.scroll-indicator.hidden{opacity:0;pointer-events:none}.scroll-indicator:after{content:"";display:block;width:1px;height:30px;background:var(--color-dusty-rose);margin:10px auto 0;animation:scrollPulse 2s ease-in-out infinite}@keyframes scrollPulse{0%,to{transform:scaleY(1);opacity:.5}50%{transform:scaleY(1.5);opacity:1}}.progress-bar{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--color-rose),var(--color-deep-rose));z-index:1000;transition:width .1s ease-out}@media (max-width: 768px){.chapter{padding:60px 20px}.poem{padding:2rem 1rem}.poem:before,.poem:after{font-size:2.5rem}.message-container{max-width:280px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.floating-hearts{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;overflow:hidden}.heart{position:absolute;font-size:1rem;color:var(--color-blush);opacity:.3;animation:float 15s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(100vh) rotate(0);opacity:0}10%{opacity:.3}90%{opacity:.3}to{transform:translateY(-100px) rotate(360deg);opacity:0}}.chapter{transition:background-color .5s ease}.poem{background:linear-gradient(135deg,#e8d5d51a,#faf8f580,#e8d5d51a);border-radius:8px}.landing{position:relative;overflow:hidden}.landing:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at center,rgba(232,213,213,.3) 0%,transparent 50%);animation:pulse 8s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(1.1);opacity:.3}}.message-container{perspective:1000px}.message-bubble{transform-style:preserve-3d;transition:transform .3s ease,box-shadow .3s ease}.message-bubble:hover{transform:translateY(-2px) rotateX(2deg);box-shadow:0 4px 20px #00000014}.love-list li{transition:all .3s ease}.love-list li:hover{padding-left:2.5rem;color:var(--color-charcoal)}.love-list li:hover:before{transform:scale(1.2)}.cta-button{position:relative;overflow:hidden}.cta-button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:radial-gradient(circle,rgba(212,165,165,.3) 0%,transparent 70%);transform:translate(-50%,-50%);transition:width .6s ease,height .6s ease}.cta-button:hover:before{width:300px;height:300px}.final-chapter{position:relative}.final-chapter:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 10 C25 5, 15 5, 15 15 C15 25, 30 35, 30 35 C30 35, 45 25, 45 15 C45 5, 35 5, 30 10' fill='none' stroke='%23e8d5d5' stroke-width='0.5' opacity='0.3'/%3E%3C/svg%3E");background-size:60px 60px;opacity:.5;pointer-events:none}@media (max-width: 480px){.landing-title{padding:0 10px}.chapter-title{font-size:2rem}.poem{font-size:1.2rem;padding:1.5rem 1rem}.love-list li{font-size:1rem;padding:.75rem 0 .75rem 1.5rem}.final-title{font-size:2.5rem}}@media print{.progress-bar,.scroll-indicator,.floating-hearts,.cta-button{display:none!important}.chapter{min-height:auto;page-break-inside:avoid;padding:40px 20px}.poem{background:none;border:1px solid #e8d5d5}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}html{scroll-behavior:auto}}@media (prefers-contrast: high){:root{--color-charcoal: #000;--color-soft-gray: #333;--color-deep-rose: #8b4444}.poem{border:2px solid var(--color-deep-rose)}}.story-page{min-height:100vh;background:linear-gradient(180deg,#faf8f5,#fff 60%,#faf8f5);color:var(--color-charcoal)}.story-hero{padding:clamp(2.5rem,5vw,4rem) 1.25rem 2rem;text-align:center;position:relative;overflow:hidden}.story-hero:before{content:"";position:absolute;top:-40%;right:-40%;bottom:-40%;left:-40%;background:radial-gradient(circle at center,rgba(232,213,213,.35) 0%,transparent 55%);animation:storyPulse 10s ease-in-out infinite;pointer-events:none}@keyframes storyPulse{0%,to{transform:scale(1);opacity:.7}50%{transform:scale(1.1);opacity:.45}}.story-title{font-family:var(--font-serif);font-size:clamp(2.2rem,5vw,3.2rem);color:var(--color-charcoal);letter-spacing:-.02em;margin:0;position:relative}.story-subtitle{margin:.75rem auto 0;max-width:42rem;color:var(--color-soft-gray);font-family:var(--font-sans);font-size:clamp(1rem,2.3vw,1.15rem);position:relative}.story-hero-actions{margin-top:1.75rem;display:flex;justify-content:center;gap:1rem;position:relative}.story-back{display:inline-flex;align-items:center;gap:.4rem;text-decoration:none;color:var(--color-charcoal);font-family:var(--font-sans);padding:.75rem 1rem;border-radius:999px;border:1px solid rgba(0,0,0,.08);background:#ffffffb3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:transform .2s ease,box-shadow .2s ease}.story-back:hover{transform:translateY(-1px);box-shadow:0 8px 30px #00000014}.story-content{padding:0 1.25rem 5rem}.story-section{max-width:900px;margin:0 auto;padding:2rem 0}.story-section-title{font-family:var(--font-serif);font-size:clamp(1.4rem,3vw,1.85rem);margin:0 0 .75rem;color:var(--color-charcoal)}.story-subsection-title{font-family:var(--font-serif);font-size:clamp(1.15rem,2.4vw,1.4rem);margin:0 0 .75rem;color:var(--color-charcoal)}.story-section-note{margin:0 0 1.25rem;color:var(--color-soft-gray);font-family:var(--font-sans)}.story-text-block{background:#ffffffb8;border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:1.25rem;box-shadow:0 10px 35px #0000000d;font-family:var(--font-sans);color:var(--color-charcoal);line-height:1.7}.story-paragraph{margin:0 0 1rem}.story-paragraph:last-child{margin-bottom:0}.story-part-grid{display:grid;grid-template-columns:1.35fr .65fr;gap:1rem;align-items:start}.story-part-photo{position:sticky;top:1.25rem}.story-photo--big{min-height:260px}.story-photo-img{width:100%;height:100%;display:block;object-fit:cover;transform:scale(1.01);filter:saturate(1.02) contrast(1.02)}.story-timeline{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem}.story-timeline-item{grid-column:span 6;background:#ffffffb8;border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:1rem 1.1rem;box-shadow:0 10px 35px #0000000d}.story-timeline-top{display:flex;align-items:baseline;justify-content:space-between;gap:1rem}.story-timeline-label{font-family:var(--font-sans);font-weight:700;color:var(--color-charcoal)}.story-timeline-date{font-family:var(--font-sans);font-weight:700;color:var(--color-charcoal);opacity:.9}.story-timeline-note{margin-top:.4rem;font-family:var(--font-sans);color:var(--color-soft-gray)}.story-if-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem}.story-if-card{grid-column:span 6;background:#ffffffb8;border:1px solid rgba(0,0,0,.06);border-radius:16px;overflow:hidden;box-shadow:0 10px 35px #0000000d;display:grid;grid-template-columns:140px 1fr;align-items:stretch}.story-if-image{position:relative;background:#e8d5d52e}.story-if-img{width:100%;height:100%;display:block;object-fit:cover}.story-if-placeholder{height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--font-sans);color:var(--color-soft-gray);border-right:1px dashed rgba(0,0,0,.14)}.story-if-text{padding:.95rem 1rem;font-family:var(--font-sans)}.story-if-title{color:var(--color-soft-gray);font-weight:600;letter-spacing:.01em}.story-if-value{margin-top:.2rem;color:var(--color-charcoal);font-weight:800}.story-if-line{margin-top:.55rem;color:var(--color-charcoal);line-height:1.6}.story-photo-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem}.story-photo{grid-column:span 4;min-height:160px;border-radius:16px;border:1px dashed rgba(0,0,0,.18);background:#ffffffb3;overflow:hidden;position:relative}.story-photo:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(232,213,213,.18) 0%,transparent 60%);pointer-events:none}.story-photo-inner{height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:1.25rem;text-align:center;font-family:var(--font-sans);position:relative;z-index:1}.story-photo-title{font-weight:700;color:var(--color-charcoal)}.story-photo-subtitle{margin-top:.25rem;color:var(--color-soft-gray);font-size:.95rem}.story-footer{padding-top:3rem}.story-footer-card{border-radius:18px;padding:1.5rem;background:linear-gradient(135deg,#e8d5d538,#ffffffd9 60%,#e8d5d52e);border:1px solid rgba(0,0,0,.06);box-shadow:0 12px 40px #0000000f;text-align:center}.story-footer-title{font-family:var(--font-serif);font-size:1.6rem;color:var(--color-charcoal)}.story-footer-subtitle{margin-top:.5rem;font-family:var(--font-sans);color:var(--color-soft-gray)}@media (max-width: 900px){.story-part-grid{grid-template-columns:1fr}.story-part-photo{position:static}.story-timeline-item,.story-if-card{grid-column:span 12}.story-photo{grid-column:span 6}}@media (max-width: 520px){.story-if-card{grid-template-columns:1fr}.story-if-image{min-height:180px}.story-if-placeholder{border-right:none;border-bottom:1px dashed rgba(0,0,0,.14)}}@media (max-width: 560px){.story-photo{grid-column:span 12}}.theme-page{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 14% 16%,rgba(224,176,255,.75) 0%,transparent 54%),radial-gradient(circle at 12% 18%,rgba(212,165,165,.78) 0%,transparent 52%),radial-gradient(circle at 88% 20%,rgba(166,124,124,.75) 0%,transparent 52%),radial-gradient(circle at 78% 70%,rgba(224,176,255,.6) 0%,transparent 58%),radial-gradient(circle at 68% 78%,rgba(232,213,213,.9) 0%,transparent 55%),radial-gradient(circle at 22% 82%,rgba(201,177,177,.75) 0%,transparent 55%),linear-gradient(180deg,#ffffff 0%,var(--color-cream) 45%,#ffffff 100%);overflow:hidden}.theme-page:before{content:"";position:absolute;top:-40%;right:-40%;bottom:-40%;left:-40%;background:radial-gradient(circle at 15% 55%,rgba(224,176,255,.5) 0%,transparent 58%),radial-gradient(circle at 30% 40%,rgba(212,165,165,.55) 0%,transparent 55%),radial-gradient(circle at 70% 30%,rgba(232,213,213,.6) 0%,transparent 55%),radial-gradient(circle at 60% 70%,rgba(166,124,124,.45) 0%,transparent 60%);mix-blend-mode:multiply;animation:themeAurora 9s ease-in-out infinite;pointer-events:none}@keyframes themeAurora{0%,to{transform:translateZ(0) scale(1);opacity:.75}50%{transform:translate3d(2%,-1%,0) scale(1.12);opacity:.9}}.theme-back{position:fixed;top:16px;left:16px;z-index:10;text-decoration:none;color:var(--color-charcoal);font-family:var(--font-sans);padding:10px 12px;border-radius:999px;border:1px solid rgba(0,0,0,.1);background:#ffffffa6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.theme-back:hover{background:#ffffffc7}
