:root{font-family:Inter,Playfair Display,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;--text: #3a2035;--subtext: #7d405e;--accent: #c43774;--accent-soft: #ff6fa8;--intro: #7a3c5c;--bg: radial-gradient(circle at 20% 20%, #ffe1ef, #ffd7eb 38%), radial-gradient(circle at 80% 0%, #ffd2e8, #ffeef6 42%), radial-gradient(circle at 50% 80%, #ffe9f3, #ffeef6 55%);--panel: rgba(255, 255, 255, .7);--border: rgba(255, 182, 218, .5);--shadow: 0 10px 26px rgba(236, 142, 182, .2);--note-bg: #fff5fb;--timeline-line: #f2b6d4;color:var(--text);background-color:#ffeef6}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background:var(--bg);color:var(--text);overflow-x:hidden}main.app{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;padding:64px 24px 72px;text-align:center;position:relative;width:100%}h1{margin:10px 0 8px;font-size:clamp(32px,6vw,50px);letter-spacing:-.01em;font-family:Playfair Display,Inter,serif;color:var(--accent)}.sub{margin:0;color:var(--subtext)}.eyebrow{margin:0;color:var(--accent-soft);font-weight:800;letter-spacing:.1em;text-transform:uppercase;font-size:12px}.sentence{max-width:880px;text-align:center}.sentence-text{margin:0;font-size:clamp(20px,4vw,26px);line-height:1.6;color:var(--text)}.sentence-intro{color:var(--intro)}.sentence-list{display:inline}.unit{display:inline-flex;align-items:baseline;font-weight:700;color:var(--accent);white-space:nowrap;perspective:800px}.unit-number{font-variant-numeric:tabular-nums;letter-spacing:.02em;display:inline-flex;gap:0px}.unit-digit{display:inline-block;min-width:.6em;text-align:center;backface-visibility:hidden}.unit-digit.flip{animation:flipChange .52s ease;transform-origin:center bottom}@keyframes flipChange{0%{transform:rotateX(0);opacity:1}45%{transform:rotateX(-90deg);opacity:.6}55%{transform:rotateX(-90deg);opacity:.6}to{transform:rotateX(0);opacity:1}}.fade-unit-enter{opacity:0;transform:translateY(6px)}.fade-unit-enter-active{opacity:1;transform:translateY(0);transition:opacity .32s ease,transform .32s ease}.fade-unit-exit{opacity:1;transform:translateY(0)}.fade-unit-exit-active{opacity:0;transform:translateY(-6px);transition:opacity .28s ease,transform .28s ease}.note{background:var(--note-bg);border:1px solid var(--border);border-radius:16px;padding:16px 20px;max-width:640px;text-align:center;color:var(--text);box-shadow:var(--shadow)}.note p{margin:0;font-size:16px;line-height:1.5}.note-text{display:inline-block;overflow:hidden;white-space:nowrap;padding-right:2px;max-width:100%;position:relative;border-right:2px solid transparent}@keyframes caret{0%,to{border-color:transparent}50%{border-color:var(--accent)}}.note-text.typing,.note-text.erasing{animation:caret .9s step-end infinite}.note-text.done{border-right-color:var(--accent);animation:caret 1.2s step-end infinite}.totals{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:clamp(8px,3vw,12px);width:min(960px,100%);padding:clamp(10px,3vw,14px) clamp(12px,5vw,16px);background:var(--panel);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow)}.totals-heading{margin:10px 0 -4px;font-size:clamp(16px,4vw,18px);color:var(--subtext);letter-spacing:.01em}.timeline{width:min(1100px,100%);margin:0 auto;display:grid;gap:16px;align-items:start}.timeline-list{display:grid;gap:18px;width:100%;justify-items:center;position:relative}.total-item{display:grid;align-items:center;justify-items:center;gap:4px}.total-value{font-weight:800;font-size:18px;color:var(--accent);display:inline-flex;font-size:clamp(16px,5vw,18px)}.total-label{font-size:13px;letter-spacing:.02em;color:var(--subtext);font-size:clamp(11px,3.5vw,13px)}.total-digit{display:inline-block;position:relative;min-width:.75em;text-align:center;backface-visibility:hidden;transform-origin:center bottom;padding:4px 0}.total-digit.flip{animation:flipChange .52s ease}.timeline-card.vertical{--timeline-pad: clamp(12px, 3.6vw, 16px);--timeline-gutter: clamp(26px, 10vw, 42px);position:relative;background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:var(--timeline-pad);box-shadow:var(--shadow);display:grid;gap:8px;overflow:visible;width:min(680px,92vw);box-sizing:border-box;cursor:pointer;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.timeline-dot{position:absolute;top:22px;width:14px;height:14px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px #ff8ac799}.timeline-line{position:absolute;top:36px;bottom:-18px;width:2px;background:linear-gradient(180deg,var(--timeline-line),rgba(255,255,255,0))}.timeline-card.side-left{justify-self:start;padding-left:calc(var(--timeline-pad) + var(--timeline-gutter));padding-right:clamp(10px,3.4vw,18px);text-align:left}.timeline-card.side-right{justify-self:end;padding-right:calc(var(--timeline-pad) + var(--timeline-gutter));padding-left:clamp(10px,3.4vw,18px);text-align:right}.timeline-card.side-right .event-photos{justify-content:flex-end}.timeline-card.side-left .timeline-dot{left:clamp(14px,7vw,22px)}.timeline-card.side-left .timeline-line{left:clamp(20px,9vw,28px)}.timeline-card.side-right .timeline-dot{right:clamp(14px,7vw,22px)}.timeline-card.side-right .timeline-line{right:clamp(20px,9vw,28px)}.timeline-month{display:inline-flex;align-items:center;justify-content:center;position:relative;padding:4px 12px;background:var(--panel);border:1px solid var(--border);border-radius:999px;color:var(--accent);font-weight:700;letter-spacing:.02em;box-shadow:var(--shadow);margin:0 auto;width:fit-content;z-index:2;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.timeline-meta{display:grid;gap:2px}.event-date{margin:0;color:var(--subtext);font-size:13px;letter-spacing:.01em}.event-name{margin:0;color:var(--accent);font-size:18px}.event-desc{margin:0;color:var(--text);line-height:1.55}.event-photos-clip{width:100%;overflow:hidden;padding:8px 0}.event-photos{display:flex;gap:14px;overflow:visible;padding-bottom:6px;scroll-snap-type:x mandatory;scrollbar-width:thin;width:100%}.event-photos img{width:min(220px,80vw);flex:0 0 auto;aspect-ratio:4 / 3;object-fit:cover;border-radius:12px;border:1px solid var(--border);box-shadow:var(--shadow);scroll-snap-align:start;transition:transform .22s ease,box-shadow .22s ease;transform-origin:center center}.event-photos img:hover{transform:scale(1.06);box-shadow:0 12px 30px #00000040;z-index:2}.event-detail-backdrop{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:24px;z-index:999}.event-detail{position:relative;background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:22px;max-width:min(940px,96vw);max-height:82vh;overflow-y:auto;box-shadow:var(--shadow)}.event-detail-close{position:absolute;top:10px;right:10px;border:none;background:#ffffff14;color:var(--accent);width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:18px;line-height:1;display:grid;place-items:center;transition:background .16s ease,transform .16s ease}.event-detail-close:hover{background:#ffffff29;transform:scale(1.05)}.event-detail-date{margin:0 0 4px;color:var(--subtext);font-size:14px;letter-spacing:.01em}.event-detail-name{margin:0 0 8px;color:var(--accent);font-size:22px}.event-detail-desc{margin:0 0 14px;color:var(--text);line-height:1.6}.event-detail-photos{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-top:6px}.event-photos::-webkit-scrollbar{height:6px}.event-photos::-webkit-scrollbar-thumb{background:#ffb6da99;border-radius:999px}.event-photos::-webkit-scrollbar-track{background:#ffe5f299}.timeline-card.event-hidden{opacity:0;transform:translateY(18px)}.timeline-card.event-visible{opacity:1;transform:translateY(0);transition:opacity .42s ease,transform .42s ease}footer{color:#a14d77;text-align:center}
