:root{--sea:#1f6f78;--sea-deep:#13474d;--sand:#f4ece0;--foam:#eafaf7;--ink:#2a3d3a;--soft:#5c6b68;--gold:#d8a657;--shell:#fff;--paper:#fbf7ef;--rule:#e7ddc9;--tom:#1f6f78;--val:#c4727f;--font-ui:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-hand:"Caveat",cursive}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}button,input,textarea{font-family:var(--font-ui)}body{font-family:var(--font-ui);color:var(--ink);background:var(--sand);line-height:1.6;-webkit-font-smoothing:antialiased}.app{max-width:720px;margin:0 auto;min-height:100vh}.topbar{position:sticky;top:0;z-index:40;background:linear-gradient(180deg,#3a9aa0,#1f6f78);color:#fff;padding:18px 22px;box-shadow:0 2px 16px #1f6f782e}.topbar h1{font-size:1.5rem;font-weight:800;letter-spacing:-.01em}.topbar .sub{font-size:.85rem;opacity:.9;font-weight:300}.countdown{margin-top:8px;font-size:.8rem;background:#ffffff29;display:inline-block;padding:4px 12px;border-radius:20px}.tabs{display:flex;gap:6px;padding:12px 16px;background:var(--foam);position:sticky;top:0;z-index:30;border-bottom:1px solid rgba(31,111,120,.1)}.tab{flex:1;text-align:center;padding:9px 6px;border-radius:12px;font-size:.85rem;font-weight:600;color:var(--soft);background:transparent;border:none;cursor:pointer}.tab.active{background:var(--sea);color:#fff}.section{padding:22px 18px}.label{letter-spacing:.22em;text-transform:uppercase;font-size:.68rem;color:var(--gold);font-weight:700;margin-bottom:10px}.entry{border-radius:14px;padding:14px 18px 16px;margin-bottom:12px;box-shadow:0 6px 22px #1f6f7814;border:1px solid rgba(31,111,120,.07);border-left:4px solid var(--tom);background-color:var(--paper);background-image:repeating-linear-gradient(var(--paper) 0 28px,var(--rule) 28px 29px);background-position:0 40px}.entry.by-val{border-left-color:var(--val)}.entry .meta{font-family:var(--font-ui);display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.entry .who{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--tom)}.entry.by-val .who{color:var(--val)}.entry .date{font-size:.7rem;color:var(--soft)}.entry h3{font-family:var(--font-hand);font-size:1.6rem;line-height:1.2;color:var(--sea-deep);margin-bottom:2px}.entry p{font-family:var(--font-hand);font-size:1.4rem;line-height:1.45;color:var(--ink)}.entry .mood{font-size:1.1rem;margin-left:6px}.photo-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.photo{border-radius:14px;overflow:hidden;position:relative;aspect-ratio:1;background:#cfe7e6}.photo img{width:100%;height:100%;object-fit:cover;display:block}.photo .cap{position:absolute;left:0;bottom:0;width:100%;padding:8px 10px;color:#fff;font-family:var(--font-hand);font-size:1.1rem;line-height:1.2;background:linear-gradient(0deg,rgba(0,0,0,.55),transparent)}.composer{border-radius:14px;padding:16px 18px;margin-bottom:18px;box-shadow:0 6px 22px #1f6f7814;border:1px solid var(--rule);background-color:var(--paper);background-image:repeating-linear-gradient(var(--paper) 0 30px,var(--rule) 30px 31px);background-position:0 44px}.composer input[type=text],.composer textarea{width:100%;border:none;background:transparent;padding:2px;margin-bottom:8px;font-family:var(--font-hand);font-size:1.45rem;line-height:30px;color:var(--ink);caret-color:var(--sea)}.composer input[type=text]:focus,.composer textarea:focus{outline:none}.composer textarea{min-height:90px;resize:vertical}.composer input[type=text]::placeholder,.composer textarea::placeholder{color:#a8a08e}.row{display:flex;gap:10px;align-items:center}.btn{background:var(--sea);color:#fff;border:none;border-radius:10px;padding:10px 18px;font-size:.95rem;font-weight:600;cursor:pointer}.btn.ghost{background:transparent;color:var(--sea);border:1px solid var(--sea)}.who-chip{font-family:var(--font-ui);font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--tom);margin-bottom:8px}.who-chip.val{color:var(--val)}.wish{display:flex;align-items:center;gap:10px;background:var(--paper);border-radius:12px;padding:10px 14px;margin-bottom:8px;border:1px solid rgba(31,111,120,.07)}.wish input{width:20px;height:20px}.wish .t{flex:1;font-family:var(--font-hand);font-size:1.3rem;line-height:1.3}.wish.done .t{text-decoration:line-through;color:var(--soft)}.wish .by{font-size:.7rem;color:var(--soft)}.empty{text-align:center;color:var(--soft);padding:30px 10px;font-size:.95rem}.gate{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:30px;background:linear-gradient(180deg,#7ec8c8,#1f6f78);color:#fff}.gate h1{font-size:2.4rem;font-weight:800;margin-bottom:10px}.gate input{margin:18px 0;padding:12px 16px;border-radius:12px;border:none;font-size:1rem;text-align:center}.gate p{font-size:1rem;opacity:.92}.gate-btn{background:#fff;color:var(--sea);border:none;border-radius:12px;padding:12px 26px;font-size:1rem;font-weight:700;cursor:pointer}.gate-btn:disabled{opacity:.6;cursor:default}.gate-who{display:flex;gap:12px;margin-top:18px}.gate-err{margin-top:18px;background:#0000002e;padding:8px 16px;border-radius:10px;font-size:.9rem}.gate-links{margin-top:22px;display:flex;gap:10px;align-items:center;font-size:.82rem;opacity:.85}.gate-links button{background:none;border:none;color:#fff;text-decoration:underline;cursor:pointer;font-size:.82rem}.gate-note{margin-top:14px;font-size:.78rem;opacity:.8;max-width:300px}.gate-lang{position:absolute;top:16px;right:16px;display:flex;gap:6px}.gate-lang button{background:#ffffff29;border:none;color:#fff;border-radius:8px;padding:4px 10px;font-size:.72rem;font-weight:700;cursor:pointer;opacity:.8}.gate-lang button.on{background:#fff;color:var(--sea);opacity:1}.gate input+input{margin-top:0}.daycard{border-radius:18px;margin-bottom:14px;overflow:hidden;position:relative;min-height:120px;box-shadow:0 6px 22px #1f6f781a;border:1px solid rgba(31,111,120,.08);transition:transform .15s ease}.daycard.ready{cursor:pointer}.daycard.ready:active{transform:scale(.98)}.dc-kicker{position:absolute;top:12px;left:16px;z-index:2;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:#ffd87a}.dc-cover{padding:34px 18px 20px;text-align:center;color:#fff;background:linear-gradient(135deg,#3a9aa0,#13474d);min-height:120px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}.daycard.locked .dc-cover{filter:blur(1px) brightness(.85)}.daycard.locked{opacity:.85}.dc-emoji{font-size:2rem;opacity:.92}.dc-teaser{font-family:var(--font-hand);font-size:1.5rem;line-height:1.3;max-width:320px}.dc-action{margin-top:6px;font-size:.78rem;font-weight:700;background:#ffffff2e;padding:6px 14px;border-radius:20px}.dc-real{background:var(--shell)}.dc-img{width:100%;height:170px;object-fit:cover;display:block}.dc-img.placeholder{background:linear-gradient(135deg,#7ec8c8,#1f6f78)}.dc-body{padding:14px 18px 18px;background-color:var(--paper);background-image:repeating-linear-gradient(var(--paper) 0 28px,var(--rule) 28px 29px);background-position:0 46px}.dc-body h3{font-family:var(--font-hand);font-size:1.8rem;line-height:1.15;color:var(--sea-deep);margin-bottom:2px}.dc-body h3 span{font-size:1.2rem}.dc-body p{font-family:var(--font-hand);font-size:1.4rem;line-height:1.45;color:var(--ink)}@keyframes pop{0%{transform:scale(.96);opacity:.4}to{transform:scale(1);opacity:1}}.daycard.revealed .dc-real{animation:pop .35s ease}.dc-together{margin-top:10px;width:100%}.dc-together-hint{font-size:.8rem;opacity:.92;margin-bottom:8px}.dc-ready-row{display:flex;gap:8px}.dc-ready{flex:1;padding:9px;border-radius:10px;border:1px solid rgba(255,255,255,.5);background:#ffffff24;color:#fff;font-weight:700;font-size:.85rem;cursor:pointer}.dc-ready.on{background:#fff;color:var(--sea-deep);border-color:#fff}.dc-ready.val.on{color:var(--val)}.dc-ready:disabled{cursor:default}.dc-waiting{margin-top:8px;font-size:.76rem;opacity:.85;font-style:italic}.sealed{background:var(--paper);border-radius:18px;padding:18px;margin-bottom:16px;box-shadow:0 6px 22px #1f6f781a;border:1px solid rgba(216,166,87,.4)}.sealed-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.sealed-occ{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--gold)}.sealed-lock{font-size:.78rem;color:var(--soft)}.sealed-prompt{font-family:var(--font-hand);font-size:1.6rem;font-weight:600;color:var(--sea-deep);margin-bottom:14px;line-height:1.25}.sealed-mine-done{background:var(--foam);border-radius:12px;padding:14px;color:var(--sea-deep);font-size:.95rem}.sealed-partner{margin-top:10px;font-size:.82rem;color:var(--soft)}.sealed-reveal{display:flex;flex-direction:column;gap:12px}.sealed-ans{background:var(--foam);border-radius:12px;padding:14px 16px;border-left:4px solid var(--sea)}.sealed-ans.by-val{border-left-color:var(--val)}.sealed-ans .who{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--sea);margin-bottom:4px}.sealed-ans.by-val .who{color:var(--val)}.sealed-ans p{font-family:var(--font-hand);color:var(--ink);font-size:1.35rem;line-height:1.4;white-space:pre-wrap}.letter-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:24px 16px;overflow-y:auto;background:linear-gradient(180deg,#3a9aa0eb,#13474df0)}.letter{background-color:var(--paper);background-image:repeating-linear-gradient(var(--paper) 0 30px,var(--rule) 30px 31px);background-position:0 14px;border-radius:14px;max-width:380px;width:100%;padding:30px 28px 26px;margin:auto;box-shadow:0 24px 60px #00000047;position:relative}.letter .seal{position:absolute;top:-14px;left:50%;transform:translate(-50%);width:30px;height:30px;border-radius:50%;background:var(--gold);box-shadow:0 3px 10px #00000040;display:flex;align-items:center;justify-content:center;font-size:.9rem}.letter .to{font-family:var(--font-hand);font-size:1.7rem;color:var(--sea-deep);font-weight:700;margin-bottom:6px}.letter p{font-family:var(--font-hand);font-size:1.32rem;color:var(--ink);line-height:1.5;margin-bottom:12px}.letter .sign{font-family:var(--font-hand);font-size:1.32rem;color:var(--ink);margin-top:14px}.letter .sign .name{display:block;font-size:1.6rem;color:var(--tom);font-weight:700}.letter .dismiss{font-family:var(--font-ui);margin-top:20px;width:100%;background:var(--sea);color:#fff;border:none;border-radius:10px;padding:11px;font-size:.92rem;font-weight:600;cursor:pointer}.letter .reread{font-family:var(--font-ui);text-align:center;font-size:.72rem;color:var(--soft);margin-top:10px}.letter-link{display:block;margin:30px auto 0;background:none;border:none;color:var(--soft);font-size:.78rem;cursor:pointer;text-decoration:none;opacity:.75}.letter-link:hover{opacity:1;color:var(--sea)}.logout{position:absolute;top:14px;right:16px;background:#ffffff24;color:#fff;border:none;border-radius:16px;padding:5px 12px;font-size:.72rem;cursor:pointer;opacity:.85}.logout:hover{opacity:1}.tabs .tab{font-size:.8rem;letter-spacing:-.01em}.song-screen{--ink:#f4ecdf;--ink-soft:rgba(244,236,223,.62);--ink-faint:rgba(244,236,223,.34);--gold:#d9a86c;--rose:#c98a83;--bg-0:#1a1320;--bg-1:#241826;--bg-2:#2e1d2a;position:relative;overflow:hidden;min-height:calc(100vh - 120px);color:var(--ink);font-family:Jost,sans-serif;background:radial-gradient(120% 90% at 20% 10%,var(--bg-2) 0%,transparent 55%),radial-gradient(120% 100% at 85% 90%,#20131f 0%,transparent 50%),linear-gradient(160deg,var(--bg-0) 0%,var(--bg-1) 100%)}.song-screen .aura{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background:radial-gradient(40% 30% at 30% 25%,rgba(217,168,108,.1) 0%,transparent 70%),radial-gradient(45% 35% at 75% 70%,rgba(201,138,131,.1) 0%,transparent 70%);animation:song-drift 18s ease-in-out infinite alternate}@keyframes song-drift{0%{transform:translateZ(0) scale(1)}to{transform:translate3d(0,-2.5%,0) scale(1.06)}}.song-screen .motes{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;overflow:hidden}.song-screen .mote{position:absolute;bottom:-10px;width:3px;height:3px;border-radius:50%;background:var(--gold);opacity:0;box-shadow:0 0 6px #d9a86cb3;animation:song-rise linear infinite}@keyframes song-rise{0%{transform:translateY(0) translate(0);opacity:0}10%{opacity:.7}90%{opacity:.5}to{transform:translateY(-105vh) translate(20px);opacity:0}}.song-wrap{position:relative;z-index:2;max-width:760px;margin:0 auto;padding:clamp(2.5rem,7vh,5rem) 1.6rem 6rem;text-align:center}.song-eyebrow{font-family:Jost,sans-serif;font-weight:400;letter-spacing:.42em;text-transform:uppercase;font-size:.72rem;color:var(--gold);margin-bottom:1.6rem;opacity:0;animation:song-fade 1.6s ease forwards .3s}.song-title{font-family:Cormorant Garamond,serif;font-weight:500;font-style:italic;font-size:clamp(2.6rem,8vw,4.4rem);line-height:1.04;letter-spacing:.01em;margin-bottom:.5rem;color:var(--ink);opacity:0;animation:song-fade 1.8s ease forwards .6s}.song-title .amp{color:var(--rose);font-style:italic}.song-dedication{font-family:Cormorant Garamond,serif;font-style:italic;font-size:clamp(1rem,2.6vw,1.2rem);color:var(--ink-soft);margin-bottom:3.2rem;opacity:0;animation:song-fade 1.8s ease forwards 1s}.song-player{display:flex;flex-direction:column;align-items:center;gap:.9rem;margin-bottom:3.6rem;opacity:0;animation:song-fade 1.8s ease forwards 1.3s}.song-screen .play-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid rgba(217,168,108,.45);background:#d9a86c0f;color:var(--ink);font-family:Jost,sans-serif;font-weight:400;letter-spacing:.22em;text-transform:uppercase;font-size:.74rem;padding:.95rem 2.1rem;border-radius:100px;cursor:pointer;display:inline-flex;align-items:center;gap:.8rem;transition:background .4s ease,border-color .4s ease,transform .2s ease}.song-screen .play-btn:hover{background:#d9a86c24;border-color:var(--gold)}.song-screen .play-btn:active{transform:scale(.97)}.song-screen .play-btn:focus-visible{outline:2px solid var(--gold);outline-offset:3px}.song-screen .play-btn .icon{width:0;height:0;border-style:solid;border-width:6px 0 6px 10px;border-color:transparent transparent transparent var(--gold);transition:opacity .3s ease}.song-screen .play-btn.playing .icon{border:none;width:9px;height:11px;position:relative}.song-screen .play-btn.playing .icon:before,.song-screen .play-btn.playing .icon:after{content:"";position:absolute;top:0;width:3px;height:11px;background:var(--gold)}.song-screen .play-btn.playing .icon:before{left:0}.song-screen .play-btn.playing .icon:after{right:0}.song-hint{font-size:.72rem;letter-spacing:.16em;color:var(--ink-faint);text-transform:uppercase;font-weight:300}.song-screen .lyrics{display:flex;flex-direction:column;gap:.2rem;position:relative;z-index:2}.song-screen .stanza{margin-bottom:2.3rem}.song-screen .tag{font-family:Jost,sans-serif;font-size:.62rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);opacity:0;margin-bottom:1rem;transition:opacity 1.4s ease}.song-screen .tag.lit{opacity:.55}.song-screen .line{font-family:Cormorant Garamond,serif;font-weight:400;font-size:clamp(1.35rem,4.2vw,1.85rem);line-height:1.5;color:var(--ink);opacity:0;filter:blur(8px);transform:translateY(14px);transition:opacity 1.5s ease,filter 1.5s ease,transform 1.5s ease}.song-screen .line.lit{opacity:1;filter:blur(0);transform:translateY(0)}.song-screen .line .es{font-style:italic;color:var(--rose)}.song-screen .line-en{display:block;margin-top:.4rem;font-size:.5em;line-height:1.4;font-style:italic;color:var(--ink-soft);letter-spacing:.01em}.song-screen .chorus .line{font-style:italic}.song-screen .chorus .line .es{color:var(--gold);font-style:italic}.song-screen .bridge .line{color:var(--ink)}@keyframes song-fade{to{opacity:1}}@media (prefers-reduced-motion: reduce){.song-screen .aura,.song-screen .mote,.song-eyebrow,.song-title,.song-dedication,.song-player{animation:none;opacity:1}.song-screen .line{transition:opacity .6s ease;filter:none;transform:none}}
