@import"https://fonts.googleapis.com/css2?family=Google+Sans:ital,opsz,wght@0,17..18,400..700;1,17..18,400..700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #fff0f3;--surface: #ffffff;--text: #1a1015;--muted: #a07880;--border: #e21f50;--accent: #c94060;--accent-light: #fce8ed;--radius: 12px;--serif: "Google Sans", Georgia, serif}body{font-family:var(--serif);background:var(--bg);color:var(--text);min-height:100vh;padding-bottom:110px;overflow-x:hidden}#heart-canvas{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;background:#e8d5f2}.container{position:relative;z-index:1;max-width:780px;margin:0 auto;padding:0 2rem}header{position:relative;z-index:1;text-align:center;padding:3.5rem 1.5rem 2rem}header h1{font-size:2.2rem;font-weight:400;color:var(--accent);font-style:italic;letter-spacing:.04em}header p{font-size:11px;color:var(--muted);letter-spacing:.18em;text-transform:uppercase;margin-top:8px;font-style:normal;font-family:Georgia,serif}section{position:relative;z-index:1;padding:2.5rem 0}.section-label{font-size:10px;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:1.8rem;font-style:normal;font-family:Georgia,serif}.cds-grid{display:flex;gap:3rem;flex-wrap:wrap;justify-content:center}.cd-card{display:flex;flex-direction:column;align-items:center;gap:12px;cursor:pointer}.cd-disc-wrap{position:relative;width:130px;height:130px}.cd-disc{width:130px;height:130px;border-radius:50%;position:relative;background:conic-gradient(from 0deg,#d4a8b8,#edd0dc,#c49aaa,#e8c4d0,#ddb8c8,#c28899,#e0bec8,#c8a0b0,#ead0da,#be9aaa,#d8b4c4,#eeccd8,#d4a8b8 360deg);box-shadow:0 2px 16px #c850642e,inset 0 0 0 25px #ffffff12;display:flex;align-items:center;justify-content:center;transition:transform .3s ease,box-shadow .3s ease}.cd-disc:hover{transform:rotate(14deg) scale(1.06);box-shadow:0 6px 24px #c8506447}.cd-disc.spinning{animation:spin 2.8s linear infinite}.cd-disc.spinning:hover{animation:spin 2.8s linear infinite;transform:none}@keyframes spin{to{transform:rotate(360deg)}}.cd-label-inner{position:absolute;width:52px;height:52px;border-radius:50%;background:var(--accent-light);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;text-align:center;font-size:7.5px;color:var(--accent);line-height:1.35;padding:6px;font-style:italic;pointer-events:none;z-index:2}.cd-hole{position:absolute;width:14px;height:14px;border-radius:50%;background:var(--bg);border:1px solid #dbb0bc;z-index:3}.cd-title{font-size:13px;font-style:italic;color:var(--text);text-align:center;max-width:140px;line-height:1.4}.cd-playing-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 1.4s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.letter-area{display:flex;align-items:center;justify-content:center;gap:2rem;flex-wrap:wrap}.letter-btn{background:none;border:.5px solid var(--border);border-radius:var(--radius);padding:1.5rem 2rem;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:10px;transition:background .15s;color:var(--accent)}.letter-btn:hover{background:var(--accent-light)}.letter-btn svg{width:42px;height:42px}.letter-btn span{font-size:10px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;font-style:normal;font-family:Georgia,serif}.letter-desc{font-size:13px;color:var(--muted);max-width:260px;line-height:1.8;font-style:italic}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#3c0a197a;display:flex;align-items:center;justify-content:center;z-index:200;opacity:0;pointer-events:none;transition:opacity .25s}.modal-overlay.open{opacity:1;pointer-events:all}.modal{background:var(--surface);border-radius:var(--radius);border:.5px solid var(--border);width:600px;max-width:92vw;padding:2rem;position:relative;max-height:88vh;display:flex;flex-direction:column;box-shadow:0 8px 48px #c8506429}.modal-close{position:absolute;top:12px;right:14px;background:none;border:none;cursor:pointer;font-size:20px;color:var(--muted);line-height:1}.modal-close:hover{color:var(--accent)}.modal-title{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:1.2rem;font-style:normal;font-family:Georgia,serif}.page-content{flex:1;font-size:14px;line-height:1.95;color:var(--text);font-style:italic;white-space:pre-wrap;overflow-y:auto;min-height:180px}.page-nav{display:flex;align-items:center;justify-content:space-between;margin-top:1.2rem;padding-top:1rem;border-top:.5px solid var(--border)}.page-nav button{background:none;border:.5px solid var(--border);border-radius:8px;padding:6px 16px;cursor:pointer;font-size:12px;color:var(--accent);transition:background .15s;font-family:var(--serif);font-style:italic}.page-nav button:disabled{opacity:.3;cursor:default}.page-nav button:not(:disabled):hover{background:var(--accent-light)}.page-indicator{font-size:11px;color:var(--muted);letter-spacing:.06em;font-style:normal;font-family:Georgia,serif}.photo-modal{position:relative;width:90vw;height:90vw;max-width:90vh;max-height:90vh;aspect-ratio:1 / 1;border-radius:var(--radius);overflow:hidden;display:flex;align-items:center;justify-content:center}.photo-modal img{width:100%;height:100%;object-fit:cover;display:block}.spotify-card{display:flex;align-items:center;gap:16px;padding:16px 20px;border:.5px solid var(--border);border-radius:var(--radius);background:var(--surface);max-width:400px;margin:0 auto;cursor:pointer;transition:background .15s,box-shadow .15s}.spotify-card:hover{background:var(--accent-light);box-shadow:0 4px 12px #c850641f}.spotify-icon{width:48px;height:48px;border-radius:10px;background:#1db954;display:flex;align-items:center;justify-content:center;flex-shrink:0}.spotify-icon svg{width:26px;height:26px;fill:#fff}.spotify-info p{font-size:14px;font-style:italic}.spotify-info span{font-size:12px;color:var(--muted);font-style:normal;font-family:Georgia,serif}.spotify-link{font-size:12px;color:var(--accent);text-decoration:none;display:inline-flex;align-items:center;gap:4px;margin-top:5px;font-style:normal;font-family:Georgia,serif}.spotify-link:hover{text-decoration:underline}.now-playing{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:.5px solid var(--border);padding:0 2rem;height:82px;display:flex;align-items:center;gap:1.5rem;z-index:100;box-shadow:0 -4px 24px #c8506417}.np-info{min-width:130px;max-width:170px}.np-info p{font-size:13px;font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.np-info span{font-size:11px;color:var(--muted);font-style:normal;font-family:Georgia,serif}.np-controls{display:flex;align-items:center}.play-btn{background:none;border:none;cursor:pointer;color:var(--accent);display:flex;align-items:center;padding:6px;border-radius:50%;transition:background .15s}.play-btn:hover{background:var(--accent-light)}.play-btn svg{width:32px;height:32px}.np-progress{flex:1;display:flex;flex-direction:column;gap:5px}.progress-wrap{height:3px;background:var(--border);border-radius:2px;cursor:pointer;position:relative}.progress-fill{height:100%;background:var(--accent);border-radius:2px;pointer-events:none}.progress-indicator{position:absolute;width:10px;height:10px;background:var(--accent);border-radius:50%;top:50%;transform:translate(-50%,-50%);pointer-events:none;box-shadow:0 2px 6px #c940604d}.progress-times{display:flex;justify-content:space-between;font-size:10px;color:var(--muted);font-style:normal;font-family:Georgia,serif}.lyrics-box{width:170px;height:62px;overflow-y:auto;border:.5px solid var(--border);border-radius:8px;padding:7px 12px;font-size:11px;line-height:1.75;color:var(--muted);background:var(--accent-light);flex-shrink:0;font-style:italic;white-space:pre-wrap;cursor:pointer;transition:height .3s ease,transform .3s ease}.lyrics-box.expanded{position:fixed;bottom:82px;left:50%;transform:translate(-50%);width:90vw;max-width:600px;height:400px;z-index:150;box-shadow:0 -4px 24px #c8506433}.lyrics-box .empty{color:var(--muted);font-style:italic}.photos-grid{display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:center;margin-bottom:2rem}.photo-placeholder{width:160px;height:160px;background:var(--surface);border:2px dashed var(--border);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,border-color .15s;position:relative;overflow:hidden}.photo-placeholder:hover{background:var(--accent-light);border-color:var(--accent)}.photo-placeholder img{width:100%;height:100%;object-fit:cover;border-radius:calc(var(--radius) - 2px)}.photo-placeholder-text{text-align:center;color:var(--muted);font-size:12px;font-style:italic;pointer-events:none}
