:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#32111f;background:#fff7fb;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--bg: #fff7fb;--bg-strong: #ffe7f1;--text: #32111f;--muted: #80546a;--primary: #d6336c;--primary-dark: #a61e4d;--card: rgba(255, 255, 255, .74);--border: rgba(214, 51, 108, .18);--shadow: 0 24px 80px rgba(166, 30, 77, .16)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at top left,rgba(255,135,171,.35),transparent 30rem),radial-gradient(circle at bottom right,rgba(255,214,231,.75),transparent 26rem),var(--bg)}button,input,textarea{font:inherit}button{cursor:pointer}.page-shell,.main-page{position:relative;min-height:100vh;overflow:hidden}.landing{display:grid;place-items:center;padding:1.25rem}.question-card{width:min(100%,42rem);position:relative;z-index:2;padding:clamp(2rem,6vw,4.5rem);border:1px solid var(--border);border-radius:2rem;background:var(--card);box-shadow:var(--shadow);text-align:center;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.question-card h1,.hero h1{margin:0;letter-spacing:-.055em;line-height:.95;font-size:clamp(3rem,12vw,7rem)}.question{margin:1.5rem auto 0;max-width:32rem;color:var(--muted);font-size:clamp(1.2rem,3vw,1.65rem);line-height:1.45}.tiny-label{margin:0 0 1rem;color:var(--primary);font-size:.78rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase}.button-row{display:flex;flex-wrap:wrap;justify-content:center;gap:.9rem;margin-top:2rem}.button{border:0;border-radius:999px;padding:.95rem 1.35rem;font-weight:800;transition:transform .18s ease,box-shadow .18s ease,background .18s ease}.button:hover{transform:translateY(-2px)}.button.primary{color:#fff;background:linear-gradient(135deg,var(--primary),var(--primary-dark));box-shadow:0 12px 24px #d6336c47}.button.secondary{color:var(--primary-dark);background:#fff;border:1px solid var(--border)}.hint{margin:1.35rem auto 0;max-width:28rem;color:var(--muted);font-size:.95rem}.shake{animation:shake .42s ease}.scroll-hint{position:absolute;bottom:3rem;left:50%;transform:translate(-50%);text-align:center;animation:bounce 2s infinite}.scroll-hint p{margin:0 0 .5rem;font-size:.85rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.scroll-arrow{font-size:1.5rem;color:var(--primary);animation:arrow-bounce 2s infinite}@keyframes bounce{0%,to{opacity:.6}50%{opacity:1}}@keyframes arrow-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(8px)}}.section{width:min(100% - 2rem,70rem);margin:0 auto;padding:clamp(3rem,8vw,7rem) 0;position:relative;z-index:2}.hero{min-height:92vh;display:flex;flex-direction:column;justify-content:center;text-align:center}.hero-subtitle{width:min(100%,44rem);margin:1.5rem auto 0;color:var(--muted);font-size:clamp(1.1rem,2.5vw,1.45rem);line-height:1.6}.date-pill{display:inline-flex;align-items:center;gap:.75rem;align-self:center;margin-top:2rem;padding:.75rem 1rem;border:1px solid var(--border);border-radius:999px;background:#ffffffb8;box-shadow:0 12px 34px #a61e4d17}.date-pill span{color:var(--muted)}.cards-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.soft-card,.photo-card,.letter-card,.timeline-item{border:1px solid var(--border);border-radius:1.6rem;background:#ffffffb8;box-shadow:0 16px 54px #a61e4d17;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.soft-card{padding:1.4rem}.soft-card h2,.section-heading h2,.letter-card h2{margin:0;color:var(--text);letter-spacing:-.04em;line-height:1;font-size:clamp(2rem,6vw,4rem)}.soft-card p,.section-heading p,.timeline-item p,.letter-card p,.photo-card p{color:var(--muted);line-height:1.7}.section-heading{margin-bottom:2rem;text-align:center}.section-heading p:not(.tiny-label){margin:.8rem auto 0;max-width:38rem}.photo-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}.photo-card{overflow:hidden}.photo-card img,.photo-placeholder{width:100%;aspect-ratio:4 / 5;display:block;object-fit:cover}.photo-placeholder{display:grid;place-items:center;padding:1rem;text-align:center;background:linear-gradient(135deg,#ff87ab2e,#fff9),var(--bg-strong)}.photo-placeholder span{display:block;color:var(--primary-dark);font-size:1.4rem;font-weight:900}.photo-placeholder small{display:block;margin-top:.25rem;color:var(--muted)}.photo-card p{margin:0;padding:1rem}.vertical-timeline{position:relative;max-width:800px;margin:0 auto;padding:2rem 0}.vertical-timeline:before{content:"";position:absolute;left:2rem;top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--primary),var(--primary-dark));opacity:.3}.timeline-item-modern{position:relative;display:grid;grid-template-columns:4rem 1fr;gap:2rem;padding:2rem 0;margin-bottom:2rem}.timeline-marker{position:relative;display:flex;justify-content:center;align-items:flex-start;padding-top:.5rem}.timeline-dot{position:relative;z-index:2;width:4rem;height:4rem;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));box-shadow:0 4px 12px #a61e4d4d;display:grid;place-items:center;border:4px solid var(--bg);transition:transform .3s ease,box-shadow .3s ease}.timeline-dot:hover{transform:scale(1.1);box-shadow:0 6px 20px #a61e4d80}.timeline-number{color:#fff;font-weight:900;font-size:1.25rem}.timeline-content{display:flex;flex-direction:column;gap:1.25rem;padding:1.5rem;border-radius:1rem;background:var(--card);border:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 20px #a61e4d14;transition:all .3s ease}.timeline-content:hover{box-shadow:0 8px 32px #a61e4d26;transform:translateY(-2px)}.timeline-image-wrapper{width:100%;border-radius:.75rem;overflow:hidden;background:var(--bg-strong);display:flex;align-items:center;justify-content:center}.timeline-image{width:100%;height:auto;max-height:400px;object-fit:contain;transition:transform .3s ease}.timeline-content:hover .timeline-image{transform:scale(1.05)}.timeline-image-placeholder{width:100%;min-height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--muted);text-align:center;padding:1rem;background:linear-gradient(135deg,var(--bg-strong),rgba(255,135,171,.2))}.timeline-image-placeholder span{font-weight:600;color:var(--primary)}.timeline-image-placeholder small{font-size:.75rem;color:var(--muted)}.timeline-text{display:flex;flex-direction:column;gap:.75rem}.timeline-date{margin:0;font-size:.9rem;color:var(--primary);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.timeline-text h3{margin:0;font-size:1.4rem;color:var(--text);line-height:1.3}.timeline-text p{margin:0;color:var(--muted);line-height:1.6;font-size:.95rem}@media(max-width:640px){.vertical-timeline:before{left:1rem}.timeline-item-modern{grid-template-columns:3rem 1fr;gap:1rem}.timeline-dot{width:3rem;height:3rem}.timeline-number{font-size:1rem}.timeline-content{padding:1rem}}.letter-card{width:min(100%,52rem);margin:0 auto;padding:clamp(1.5rem,5vw,3rem)}.letter-card h2{margin-bottom:1.5rem}.letter-card p:not(.tiny-label){font-size:1.08rem}.footer{position:relative;z-index:2;padding:3rem 1rem 5rem;text-align:center}.footer p{margin:0;color:var(--primary-dark);font-size:clamp(2.8rem,10vw,7rem);font-weight:950;letter-spacing:-.06em}.floating-hearts{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:1}.heart{position:absolute;left:var(--left);bottom:-3rem;color:#d6336c2b;font-size:var(--size);animation:float-heart var(--duration) linear infinite;animation-delay:var(--delay)}@keyframes float-heart{0%{transform:translateZ(0) rotate(0);opacity:0}15%{opacity:1}to{transform:translate3d(0,-115vh,0) rotate(40deg);opacity:0}}@keyframes rise-in{0%{opacity:0;transform:translateY(18px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-5px)}80%{transform:translate(5px)}}@media(max-width:840px){.cards-grid,.photo-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:560px){.question-card{border-radius:1.5rem}.button-row{flex-direction:column}.button{width:100%}.cards-grid,.photo-grid{grid-template-columns:1fr}.date-pill{flex-direction:column;gap:.25rem}}
