@font-face{font-family:Fraunces;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/fraunces-vietnamese-400-normal-CvGt0Ybw.woff2) format("woff2"),url(/assets/fraunces-vietnamese-400-normal-B65MOf9T.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Fraunces;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/fraunces-latin-ext-400-normal-D8gbi3Gu.woff2) format("woff2"),url(/assets/fraunces-latin-ext-400-normal-UihxqfOe.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Fraunces;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/fraunces-latin-400-normal-6IfK1voy.woff2) format("woff2"),url(/assets/fraunces-latin-400-normal-NUPT2cO8.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Fraunces;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/fraunces-vietnamese-500-normal-GOH_-EGq.woff2) format("woff2"),url(/assets/fraunces-vietnamese-500-normal-B-KbxExq.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Fraunces;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/fraunces-latin-ext-500-normal-Z5DV8IzT.woff2) format("woff2"),url(/assets/fraunces-latin-ext-500-normal-BMcFk1Xs.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Fraunces;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/fraunces-latin-500-normal-DnGCNyPD.woff2) format("woff2"),url(/assets/fraunces-latin-500-normal-BTR4KCeb.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Fraunces;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/fraunces-vietnamese-600-normal-BjlAJixd.woff2) format("woff2"),url(/assets/fraunces-vietnamese-600-normal-DlAl5EAR.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Fraunces;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/fraunces-latin-ext-600-normal-BtzmzP0X.woff2) format("woff2"),url(/assets/fraunces-latin-ext-600-normal-B0Dy4lqi.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Fraunces;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/fraunces-latin-600-normal-BFCDtZfi.woff2) format("woff2"),url(/assets/fraunces-latin-600-normal-DL5QCzvS.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--c-bg: #f6f0ea;--c-ink: #1f1d1b;--c-ink-soft: #4a3a2f;--c-ink-muted: #6d5345;--c-ink-faint: #7a5d4b;--c-eyebrow: #a1795e;--c-accent-warm: #c96f3a;--c-accent-deep: #b4572d;--c-accent-rose: #ff6d94;--c-accent-peach: #ff9d6e;--c-accent-sun: #f6c957;--c-accent-leaf: #83d5a0;--c-accent-sky: #7cbdf2;--c-accent-violet: #9047e5;--c-surface: rgba(255, 250, 246, .94);--c-surface-alt: rgba(255, 243, 252, .94);--c-surface-warm: #fff8f2;--c-surface-cool: #fff0fb;--c-border-warm: #efd3e4;--c-border-cool: #c9bee5;--c-border-peach: #edd2bc;--c-border-dashed: #e7cbb4;--grad-rainbow: linear-gradient( 90deg, #ff6d94 0%, #ff9d6e 34%, #f6c957 68%, #83d5a0 100% );--grad-card: linear-gradient(140deg, #fff8f2, #fff0fb);--grad-card-loaded: linear-gradient(145deg, #f5e8ff, #ebf5ff);--grad-letter-filled: linear-gradient(140deg, #ffe4f4, #efe5ff);--grad-header: linear-gradient(125deg, rgba(255, 244, 250, .82), rgba(255, 246, 227, .84)), radial-gradient(circle at top right, rgba(177, 221, 255, .36), transparent 44%);--grad-station: linear-gradient(130deg, rgba(255, 249, 245, .92), rgba(255, 243, 252, .92)), radial-gradient(circle at top right, rgba(168, 216, 255, .3), transparent 42%);--grad-future: linear-gradient(135deg, rgba(255, 247, 240, .94) 0%, rgba(255, 236, 246, .94) 52%, rgba(234, 243, 255, .92) 100%), radial-gradient(circle at top right, rgba(255, 208, 143, .34), transparent 40%);--grad-viewer: linear-gradient(128deg, rgba(255, 250, 246, .97), rgba(255, 243, 252, .95)), radial-gradient(circle at top right, rgba(163, 214, 255, .22), transparent 42%);--shadow-soft: 0 16px 34px rgba(159, 109, 143, .12);--shadow-card: 0 14px 28px rgba(168, 96, 152, .18);--shadow-button: 0 10px 20px rgba(120, 83, 63, .2);--shadow-modal: 0 30px 80px rgba(72, 41, 73, .28);--shadow-letter: 0 10px 26px rgba(180, 119, 168, .14);--r-sm: 10px;--r-md: 14px;--r-lg: 18px;--r-xl: 24px;--r-xxl: 28px;--r-pill: 999px;--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 20px;--s-6: 24px;--s-7: 32px;--s-8: 48px;--font-display: "Fraunces", Georgia, "Cormorant Garamond", serif;--font-body: "Outfit", system-ui, -apple-system, sans-serif;--fs-eyebrow: 12px;--fs-sm: .85rem;--fs-base: 1rem;--fs-lg: 1.25rem;--fs-h2: clamp(1.6rem, 2.5vw, 2.3rem);--fs-h1: clamp(2.4rem, 4.2vw, 3.6rem);--ease-soft: cubic-bezier(.4, .2, .2, 1);--ease-pop: cubic-bezier(.2, .9, .3, 1.3);--t-fast: .18s;--t-med: .32s;--t-slow: .52s;--t-theme: .9s;--theme-primary: #ffb3c6;--theme-secondary: #ffd6a5;--theme-accent: #ef476f;--theme-ink: #5c2233}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{color-scheme:light}body{min-height:100vh;font-family:var(--font-body);line-height:1.55;color:var(--c-ink);background:radial-gradient(circle at 8% 10%,rgba(255,169,196,.34),transparent 34%),radial-gradient(circle at 92% 18%,rgba(166,214,255,.34),transparent 36%),radial-gradient(circle at 30% 90%,rgba(255,206,137,.26),transparent 30%),radial-gradient(circle at 84% 82%,rgba(177,238,194,.24),transparent 32%),var(--c-bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body.modal-open{overflow:hidden}#root{min-height:100vh}button{font:inherit}h1,h2,h3{font-family:var(--font-display);font-weight:500;letter-spacing:-.015em;line-height:1.15}.app{position:relative;isolation:isolate;max-width:1100px;margin:0 auto;padding:var(--s-8) var(--s-6) 72px;display:grid;gap:var(--s-7);transition:--theme-primary var(--t-theme) var(--ease-soft),--theme-secondary var(--t-theme) var(--ease-soft),--theme-accent var(--t-theme) var(--ease-soft),--theme-ink var(--t-theme) var(--ease-soft)}@property --theme-primary{syntax: "<color>"; inherits: true; initial-value: #ffb3c6;}@property --theme-secondary{syntax: "<color>"; inherits: true; initial-value: #ffd6a5;}@property --theme-accent{syntax: "<color>"; inherits: true; initial-value: #ef476f;}@property --theme-ink{syntax: "<color>"; inherits: true; initial-value: #5c2233;}.app:before{background:radial-gradient(circle,color-mix(in srgb,var(--theme-primary) 38%,transparent) 0%,transparent 72%)!important;transition:background var(--t-theme) var(--ease-soft)}.app:after{background:radial-gradient(circle,color-mix(in srgb,var(--theme-secondary) 35%,transparent) 0%,transparent 70%)!important;transition:background var(--t-theme) var(--ease-soft)}.grain{position:fixed;inset:0;z-index:50;pointer-events:none;opacity:.12;mix-blend-mode:multiply;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.2 0 0 0 0 0.15 0 0 0 0 0.1 0 0 0 0.6 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");background-size:200px 200px}@media(prefers-reduced-motion:reduce){.grain{opacity:.08}}.app:before,.app:after{content:"";position:absolute;z-index:-1;pointer-events:none}.app:before{width:420px;height:420px;top:-140px;right:-100px;background:radial-gradient(circle,#ff8faa42,#ff8faa00 72%)}.app:after{width:360px;height:360px;bottom:-10px;left:-150px;background:radial-gradient(circle,#76bbff38,#76bbff00 70%)}.journey-header{display:grid;gap:var(--s-3);padding:var(--s-6) var(--s-6) var(--s-5);border-radius:var(--r-xl);border:1px solid rgba(241,191,174,.65);background:var(--grad-header);box-shadow:var(--shadow-soft)}.journey-eyebrow{text-transform:uppercase;letter-spacing:.22em;font-size:var(--fs-eyebrow);color:var(--c-eyebrow)}.journey-header h1{font-size:var(--fs-h1)}.journey-subtitle{max-width:620px;color:var(--c-ink-soft)}.journey-meta{display:inline-flex;flex-wrap:wrap;gap:var(--s-3);align-items:center;width:fit-content;padding:var(--s-3) var(--s-4);border-radius:var(--r-pill);border:1px solid #e4c6b1;background:#fff8f1d9;color:var(--c-ink-faint)}.journey-meta strong{color:var(--c-accent-deep)}.journey-love-note{max-width:700px;color:var(--c-ink-muted);font-style:italic}main{display:grid;gap:var(--s-6)}.station-panel{background:linear-gradient(135deg,color-mix(in srgb,var(--theme-primary) 28%,#fff),color-mix(in srgb,var(--theme-secondary) 22%,#fff));border-radius:var(--r-xl);padding:var(--s-7);border:1px solid color-mix(in srgb,var(--theme-accent) 30%,transparent);display:grid;gap:var(--s-6);box-shadow:0 20px 50px color-mix(in srgb,var(--theme-ink) 18%,transparent);transition:background var(--t-theme) var(--ease-soft),border-color var(--t-theme) var(--ease-soft),box-shadow var(--t-theme) var(--ease-soft);animation:panel-in .7s var(--ease-pop) both}@keyframes panel-in{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.station-mood{color:var(--theme-accent);font-weight:600}.station-label-sep{margin:0 6px;opacity:.5}.station-header{display:grid;gap:var(--s-2)}.station-label{text-transform:uppercase;letter-spacing:.22em;font-size:var(--fs-eyebrow);color:var(--c-eyebrow)}.station-header h2{font-size:var(--fs-h2)}.station-subtitle{color:#5b4740}.station-dedication{font-size:.98rem;color:var(--c-ink-faint);font-style:italic}.station-footer{display:flex;flex-wrap:wrap;justify-content:space-between;gap:var(--s-3);align-items:center}.station-progress{font-weight:600;color:#5b4740}.station-progress-note{margin-top:-10px;color:var(--c-ink-faint);font-size:.95rem}.future-panel{display:grid;justify-items:center;padding:40px 20px 60px;perspective:1200px;animation:panel-in .9s var(--ease-pop) both}.envelope{position:relative;width:min(640px,100%);transform-style:preserve-3d;transition:transform 1.1s var(--ease-pop)}.envelope.opened .envelope-flap{transform:rotateX(175deg)}.envelope.opened .letter-paper{transform:translateY(-120%) rotate(-.3deg)}.envelope.opened .envelope-seal{opacity:0;transform:translate(-50%) scale(.4)}.envelope-flap{position:absolute;top:0;left:0;right:0;height:140px;z-index:4;background:linear-gradient(180deg,color-mix(in srgb,var(--theme-accent) 60%,#fff),color-mix(in srgb,var(--theme-accent) 85%,var(--theme-ink)));clip-path:polygon(0 0,100% 0,50% 100%);transform-origin:top center;transform:rotateX(0);transition:transform 1.3s var(--ease-soft);box-shadow:0 8px 16px color-mix(in srgb,var(--theme-ink) 30%,transparent)}.envelope-seal{position:absolute;top:62px;left:50%;transform:translate(-50%) scale(1);z-index:5;width:44px;height:44px;border-radius:999px;background:radial-gradient(circle at 35% 30%,color-mix(in srgb,var(--theme-primary) 90%,#fff),var(--theme-accent) 60%,var(--theme-ink) 100%);color:#fff;display:grid;place-items:center;font-size:22px;box-shadow:0 4px 10px color-mix(in srgb,var(--theme-ink) 40%,transparent);transition:opacity .8s var(--ease-soft),transform .8s var(--ease-pop)}.letter-paper{position:relative;z-index:1;background:#fffbf2;border-radius:6px;padding:56px 48px 42px;transform:translateY(0);transition:transform 1.3s var(--ease-pop) .2s;box-shadow:0 30px 60px color-mix(in srgb,var(--theme-ink) 22%,transparent),0 0 0 1px color-mix(in srgb,var(--theme-ink) 8%,transparent);background-image:repeating-linear-gradient(to bottom,transparent 0,transparent 28px,color-mix(in srgb,var(--theme-accent) 10%,transparent) 28px,color-mix(in srgb,var(--theme-accent) 10%,transparent) 29px)}.letter-paper:before,.letter-paper:after{content:"";position:absolute;width:40px;height:40px;background:radial-gradient(circle,color-mix(in srgb,var(--theme-accent) 40%,transparent) 0%,transparent 70%);top:20px;opacity:.6}.letter-paper:before{left:20px}.letter-paper:after{right:20px}.letter-paper-inner{position:relative;text-align:left;display:grid;gap:16px}.letter-greeting{font-family:var(--font-display);font-size:1.3rem;color:var(--theme-ink);font-style:italic}.collected-letters{display:flex;justify-content:center;gap:10px;padding:14px 0;font-family:var(--font-display);font-size:2.4rem;letter-spacing:.08em;color:var(--theme-accent);font-weight:600}.collected-letter{display:inline-block;opacity:0;transform:translateY(-14px) scale(.4);animation:letter-drop .7s var(--ease-pop) both;text-shadow:0 4px 10px color-mix(in srgb,var(--theme-ink) 25%,transparent)}@keyframes letter-drop{0%{opacity:0;transform:translateY(-24px) scale(.4) rotate(-10deg)}60%{opacity:1;transform:translateY(4px) scale(1.1) rotate(3deg)}to{opacity:1;transform:translateY(0) scale(1) rotate(0)}}.letter-title{font-size:clamp(1.3rem,2.2vw,1.9rem);color:var(--theme-ink);text-align:center;max-width:580px;margin:0 auto}.letter-body{color:var(--c-ink-muted);text-align:center;max-width:520px;margin:0 auto;line-height:1.7}.letter-signature{font-family:var(--font-display);font-style:italic;text-align:right;color:var(--theme-accent);padding-top:var(--s-3)}@media(max-width:600px){.letter-paper{padding:46px 28px 34px}.collected-letters{font-size:1.8rem;gap:6px}}@media(max-width:720px){.app{padding:34px 18px 56px;gap:var(--s-6)}.station-panel{padding:var(--s-6)}.station-footer{flex-direction:column;align-items:flex-start}.journey-meta{width:100%;border-radius:var(--r-md)}.future-panel{padding:var(--s-6)}}.letter-assembly{display:grid;gap:var(--s-3);justify-items:center}.letter-assembly-label{font-size:var(--fs-eyebrow);text-transform:uppercase;letter-spacing:.22em;color:var(--c-eyebrow)}.letter-assembly-row{display:flex;gap:var(--s-3);padding:var(--s-3) var(--s-4);border-radius:var(--r-pill);background:linear-gradient(120deg,#fff7f0,#fff2ff);border:1px solid #efcfe6;box-shadow:var(--shadow-letter)}.letter-slot{width:28px;height:36px;border-radius:var(--r-sm);display:grid;place-items:center;font-weight:700;font-family:var(--font-display);font-size:1rem;color:#d7b39a;background:#fffaf6;border:1px dashed var(--c-border-dashed);transition:transform var(--t-med) var(--ease-pop),background var(--t-med) var(--ease-soft),color var(--t-med) var(--ease-soft),border-color var(--t-med) var(--ease-soft),box-shadow var(--t-med) var(--ease-soft)}.letter-slot.filled{color:var(--c-accent-violet);border-style:solid;background:var(--grad-letter-filled);border-color:#d4b3ff;animation:slot-pop var(--t-slow) var(--ease-pop) both;box-shadow:0 0 #9047e533,0 4px 14px #9047e52e}.letter-slot.just-filled{animation:slot-glow 1.2s var(--ease-soft) both}@keyframes slot-pop{0%{transform:scale(.6) rotate(-8deg);opacity:0}55%{transform:scale(1.18) rotate(3deg);opacity:1}to{transform:scale(1) rotate(0);opacity:1}}@keyframes slot-glow{0%{box-shadow:0 0 #9047e599,0 4px 14px #9047e52e}60%{box-shadow:0 0 0 12px #9047e500,0 6px 20px #9047e547}to{box-shadow:0 0 #9047e500,0 4px 14px #9047e52e}}.memory-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--s-4)}.memory-card{position:relative;background:linear-gradient(160deg,color-mix(in srgb,var(--theme-primary) 18%,#fff),color-mix(in srgb,var(--theme-secondary) 14%,#fff));border:1px solid color-mix(in srgb,var(--theme-accent) 22%,transparent);border-radius:var(--r-lg);padding:var(--s-4);text-align:left;display:grid;gap:var(--s-2);cursor:pointer;transform:rotate(var(--tilt, 0deg));transition:transform var(--t-fast) var(--ease-soft),box-shadow var(--t-fast) var(--ease-soft),border-color var(--t-fast) var(--ease-soft),background var(--t-theme) var(--ease-soft)}.memory-card:hover,.memory-card:focus-visible{transform:rotate(0) translateY(-4px) scale(1.02);box-shadow:0 18px 36px color-mix(in srgb,var(--theme-ink) 22%,transparent);border-color:var(--theme-accent);outline:none;z-index:2}.memory-card:focus-visible{box-shadow:0 18px 36px color-mix(in srgb,var(--theme-ink) 22%,transparent),0 0 0 3px color-mix(in srgb,var(--theme-accent) 55%,transparent)}.memory-card.loaded{background:linear-gradient(160deg,color-mix(in srgb,var(--theme-primary) 30%,#fff),color-mix(in srgb,var(--theme-accent) 18%,#fff));border-color:color-mix(in srgb,var(--theme-accent) 45%,transparent)}.memory-card.loaded:after{content:"✓";position:absolute;top:10px;right:12px;width:22px;height:22px;border-radius:var(--r-pill);background:var(--theme-accent);color:#fff;display:grid;place-items:center;font-size:13px;font-weight:700;box-shadow:0 4px 12px color-mix(in srgb,var(--theme-ink) 35%,transparent);animation:slot-pop var(--t-slow) var(--ease-pop) both}.memory-type{display:inline-flex;align-items:center;gap:6px}.memory-type-icon{color:var(--theme-accent);font-size:14px}.date-chip{display:inline-grid;grid-template-columns:auto auto;grid-template-rows:auto auto;align-items:baseline;gap:0 6px;padding:6px 10px 5px;border-radius:8px;background:#fff;border:1px dashed color-mix(in srgb,var(--theme-ink) 30%,transparent);color:var(--theme-ink);width:fit-content;font-family:var(--font-display);line-height:1;position:relative}.date-chip:before,.date-chip:after{content:"";position:absolute;top:-1px;bottom:-1px;width:6px;background-image:radial-gradient(circle,#fff 2px,transparent 2.2px);background-size:6px 6px;background-position:0 0}.date-chip:before{left:-3px}.date-chip:after{right:-3px}.date-chip-month{grid-column:1;grid-row:1;font-size:9px;text-transform:uppercase;letter-spacing:.12em;font-weight:600;opacity:.75}.date-chip-day{grid-column:1;grid-row:2;font-size:18px;font-weight:600}.date-chip-year{grid-column:2;grid-row:1 / span 2;align-self:center;font-size:10px;letter-spacing:.1em;opacity:.7}.memory-type{font-size:var(--fs-eyebrow);letter-spacing:.1em;text-transform:uppercase;color:var(--c-eyebrow)}.memory-card strong{font-size:1.02rem;color:var(--c-ink-soft);font-weight:600}.memory-state{font-size:var(--fs-sm);color:var(--c-ink-muted)}.memory-summary{font-size:var(--fs-sm);color:var(--c-ink-faint)}.letter-reveal{display:flex;align-items:baseline;gap:var(--s-3);animation:slot-pop var(--t-slow) var(--ease-pop) both}.letter-label{font-size:var(--fs-eyebrow);text-transform:uppercase;letter-spacing:.18em;color:var(--c-eyebrow)}.letter-fragment{font-size:2rem;font-weight:700;font-family:var(--font-display);color:var(--c-accent-warm)}.letter-hint{color:#8a6d5a;font-style:italic}.memory-viewer{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:var(--s-4);animation:fade-in var(--t-med) var(--ease-soft) both}.viewer-backdrop{position:absolute;inset:0;background:#1d17138c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:none;cursor:pointer}.viewer-card{position:relative;z-index:1;width:min(760px,100%);max-height:min(90dvh,900px);overflow:auto;background:linear-gradient(130deg,color-mix(in srgb,var(--theme-primary) 16%,#fff),color-mix(in srgb,var(--theme-secondary) 12%,#fff));border-radius:var(--r-xl);border:1px solid color-mix(in srgb,var(--theme-accent) 35%,transparent);padding:var(--s-5) var(--s-6) var(--s-6);display:grid;gap:var(--s-4);box-shadow:var(--shadow-modal);animation:viewer-in var(--t-med) var(--ease-pop) both}.letter-assembly.dimmed{opacity:.35;filter:saturate(.6);transition:opacity var(--t-slow) var(--ease-soft),filter var(--t-slow) var(--ease-soft)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes viewer-in{0%{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.viewer-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--s-4)}.viewer-title-block{display:grid;gap:4px;min-width:0}.viewer-eyebrow{font-size:var(--fs-eyebrow);text-transform:uppercase;letter-spacing:.2em;color:var(--theme-accent);font-weight:600}.viewer-relative{font-size:var(--fs-sm);color:var(--c-ink-faint);font-style:italic}.viewer-header h3{font-size:1.5rem;color:var(--theme-ink)}.viewer-nav{display:flex;align-items:center;justify-content:space-between;gap:var(--s-3);padding-top:var(--s-2);border-top:1px dashed color-mix(in srgb,var(--theme-ink) 20%,transparent)}.viewer-nav-btn{width:40px;height:40px;border-radius:var(--r-pill);border:1px solid color-mix(in srgb,var(--theme-accent) 40%,transparent);background:color-mix(in srgb,var(--theme-primary) 18%,#fff);color:var(--theme-ink);font-size:18px;cursor:pointer;transition:transform var(--t-fast) var(--ease-soft),background var(--t-fast) var(--ease-soft)}.viewer-nav-btn:hover,.viewer-nav-btn:focus-visible{transform:scale(1.08);background:color-mix(in srgb,var(--theme-primary) 36%,#fff);outline:none}.viewer-close{background:#f3e7dc;border:1px solid #e2c9b3;border-radius:var(--r-pill);padding:6px 14px;cursor:pointer;transition:background var(--t-fast) var(--ease-soft),transform var(--t-fast) var(--ease-soft)}.viewer-close:hover,.viewer-close:focus-visible{background:#ecdccb;transform:translateY(-1px);outline:none}.viewer-body{display:grid;gap:var(--s-3)}.viewer-body p{color:var(--c-ink-muted)}.viewer-footer{font-size:var(--fs-sm);color:var(--c-ink-faint);letter-spacing:.04em}.media-frame{position:relative;border-radius:var(--r-lg);overflow:hidden;background:#fff;border:1px solid var(--c-border-peach);min-height:200px;display:grid;place-items:center}.media-frame img,.media-frame video{display:block;width:100%;max-height:70vh;object-fit:contain;background:#fff}.media-frame img.ken-burns{animation:ken-burns 18s var(--ease-soft) infinite alternate}@keyframes ken-burns{0%{transform:scale(1) translate(0)}to{transform:scale(1.06) translate(-1%,-.8%)}}@media(prefers-reduced-motion:reduce){.media-frame img.ken-burns{animation:none}}.media-frame .media-skeleton{position:absolute;inset:0;background:linear-gradient(100deg,#f7ecdf 30%,#fff4e6,#f7ecdf 70%);background-size:200% 100%;animation:shimmer 1.4s linear infinite}.media-frame.loaded .media-skeleton{display:none}.media-error{padding:var(--s-6);text-align:center;color:var(--c-ink-muted);font-style:italic}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.train-chug{position:relative;width:100%;display:grid;grid-template-rows:auto auto;row-gap:var(--s-2);padding:var(--s-2) 2px;margin:0 auto var(--s-2)}.train-chug .track{position:absolute;left:6px;right:6px;top:28px;height:4px;border-radius:var(--r-pill);background:linear-gradient(90deg,#ff779aa6,#ffa56ca6,#f6ce60a6,#89d9a9a6,#7cb7f2a6,#c295f2a6);box-shadow:0 0 14px #be7cbe59}.train-chug .train-emoji{grid-row:1;justify-self:center;filter:drop-shadow(0 6px 10px color-mix(in srgb,var(--theme-ink) 40%,transparent));transition:transform var(--t-slow) var(--ease-pop)}.svg-train{width:72px;height:auto;display:block}.train-chug .train-emoji.chug{animation:chug .9s var(--ease-soft)}.svg-train .puff{fill:var(--theme-primary);opacity:0;animation:puff 1.8s ease-out infinite}.svg-train .puff-1{animation-delay:0s}.svg-train .puff-2{animation-delay:.4s}.svg-train .puff-3{animation-delay:.8s}.svg-train .wheels circle{transform-origin:center;transform-box:fill-box;animation:spin-wheel 1.6s linear infinite}@keyframes chug{0%{transform:translateY(0) rotate(0)}25%{transform:translateY(-4px) rotate(-2deg)}50%{transform:translateY(3px) rotate(2deg)}75%{transform:translateY(-2px) rotate(-1deg)}to{transform:translateY(0) rotate(0)}}@keyframes puff{0%{transform:translate(0) scale(.6);opacity:0}30%{opacity:.8}to{transform:translate(-6px,-18px) scale(1.6);opacity:0}}@keyframes spin-wheel{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.svg-train .puff,.svg-train .wheels circle{animation:none}}.train-chug .station.filled .dot{background:linear-gradient(135deg,var(--theme-primary),var(--theme-accent));border-color:color-mix(in srgb,var(--theme-accent) 60%,transparent);box-shadow:0 0 12px color-mix(in srgb,var(--theme-accent) 40%,transparent)}.train-chug .station.active .dot{box-shadow:0 0 0 6px color-mix(in srgb,var(--theme-accent) 30%,transparent)}.train-chug .station.active .label{color:var(--theme-accent)}.train-chug.arrived .station.filled .dot{animation:dot-celebrate 1.2s var(--ease-pop) both}@keyframes dot-celebrate{0%{transform:scale(1)}50%{transform:scale(1.35)}to{transform:scale(1)}}.train-chug .stations{grid-row:2;grid-column:1 / -1;display:grid;gap:0;align-items:center;margin-top:var(--s-2)}.train-chug .station{display:grid;gap:6px;justify-items:center;background:transparent;border:none;padding:4px 2px;cursor:pointer;color:#8b678f;font:inherit;border-radius:var(--r-sm);transition:transform var(--t-fast) var(--ease-soft)}.train-chug .station:hover,.train-chug .station:focus-visible{transform:translateY(-1px);outline:none}.train-chug .station:focus-visible{box-shadow:0 0 0 3px #9047e54d}.train-chug .dot{width:14px;height:14px;border-radius:var(--r-pill);border:2px solid rgba(173,146,193,.65);background:#fff8ff;transition:background var(--t-med) var(--ease-soft),border-color var(--t-med) var(--ease-soft),box-shadow var(--t-med) var(--ease-soft)}.train-chug .station.filled .dot{background:var(--grad-rainbow);border-color:#ff91aecc}.train-chug .station.active .dot{box-shadow:0 0 0 6px #aa64d633}.train-chug .station.active .label{color:var(--c-accent-violet);font-weight:600}.train-chug .label{font-size:.75rem}.train-controls{background:var(--grad-card);border:1px solid #efcde5;border-radius:var(--r-lg);padding:var(--s-5) var(--s-6);display:grid;gap:var(--s-3);justify-items:start}.train-controls button{border:none;background:var(--grad-rainbow);color:#fff;padding:var(--s-3) var(--s-5);border-radius:var(--r-pill);font-weight:600;cursor:pointer;transition:transform var(--t-fast) var(--ease-soft),box-shadow var(--t-fast) var(--ease-soft),filter var(--t-fast) var(--ease-soft)}.train-controls button:disabled{background:linear-gradient(90deg,#d6c2ca,#d8cab7);cursor:not-allowed;box-shadow:none;filter:saturate(.6)}.train-controls button:not(:disabled):hover{transform:translateY(-1px);box-shadow:var(--shadow-button)}.train-controls button:focus-visible{outline:none;box-shadow:0 0 0 3px #9047e559,var(--shadow-button)}.train-hint{color:var(--c-ink-faint)}@media(max-width:720px){.train-controls{justify-items:stretch}.train-controls button{width:100%}.train-chug .label{font-size:.65rem}}.sparkle-sky{position:absolute;inset:-30px 0 0;z-index:-1;pointer-events:none;overflow:hidden}.sparkle-sky>span{position:absolute}.sparkle-heart{color:#de5e8d8f;font-size:20px;animation:float-heart 7s ease-in-out infinite;text-shadow:0 0 16px rgba(255,156,189,.75)}.sparkle-star{color:#ffd383d9;font-size:15px;animation:twinkle 2.8s ease-in-out infinite;text-shadow:0 0 14px rgba(255,229,156,.75)}.rainbow-ribbon{width:280px;height:140px;border-radius:280px 280px 0 0;opacity:.34;filter:blur(2px);animation:ribbon-glow 6s linear infinite;background:linear-gradient(90deg,#f48181a6,#f6b36da6 22%,#f5dc7aa6,#91d7a6a6,#82bef1a6 82%,#bc98eda6)}.rainbow-mist{width:320px;height:320px;border-radius:var(--r-pill);mix-blend-mode:screen;opacity:.24;animation:mist-drift 12s ease-in-out infinite;background:radial-gradient(circle,#ff7bb2e6,#ffb171b3 28%,#83c7ff8c 62%,#83c7ff00)}.rainbow-mist.alt{background:radial-gradient(circle,#be97ffd9,#7cddbead,#ffcf8480 72%,#ffcf8400)}@keyframes float-heart{0%{transform:translateY(0) scale(1) rotate(0);opacity:.34}50%{transform:translateY(-10px) scale(1.08) rotate(-4deg);opacity:.58}to{transform:translateY(0) scale(1) rotate(0);opacity:.34}}@keyframes twinkle{0%{opacity:.18;transform:scale(.85)}50%{opacity:.72;transform:scale(1.08)}to{opacity:.18;transform:scale(.85)}}@keyframes ribbon-glow{0%{filter:blur(2px) saturate(1)}50%{filter:blur(3px) saturate(1.2)}to{filter:blur(2px) saturate(1)}}@keyframes mist-drift{0%{transform:translate(0) scale(1)}50%{transform:translate(12px,-14px) scale(1.07)}to{transform:translate(0) scale(1)}}@media(max-width:600px){.rainbow-ribbon{width:180px;height:90px;opacity:.2}.rainbow-mist{width:210px;height:210px}.sparkle-sky>.sparkle-heart:nth-child(n+4),.sparkle-sky>.sparkle-star:nth-child(n+10){display:none}}@media(prefers-reduced-motion:reduce){.sparkle-heart,.sparkle-star,.rainbow-ribbon,.rainbow-mist,.train-chug .train-emoji.chug,.letter-slot,.letter-slot.filled,.letter-slot.just-filled,.memory-viewer,.viewer-card,.letter-reveal{animation:none!important;transition:none!important}}
