:root{--blush: #ffc2d4;--blush-soft: #ffe3ea;--rose-gold: #e8b4a0;--rose-gold-2: #b76e79;--gold: #e6c79c;--cream: #fff5f0;--plum: #1a0a14;--plum-2: #2a1320;--ink: #3a1f28}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{width:100%;height:100%;overflow:hidden;background:radial-gradient(ellipse at 50% 40%,#3a1828,#1a0a14 55%,#0c0509);font-family:Georgia,Times New Roman,serif;color:var(--cream);-webkit-user-select:none;user-select:none}#scene{position:fixed;top:0;right:0;bottom:0;left:0;display:block;touch-action:none}#vignette{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:2;background:radial-gradient(ellipse at center,transparent 55%,rgba(12,5,9,.65) 100%)}#counter{position:fixed;top:18px;left:50%;transform:translate(-50%);z-index:5;text-align:center;pointer-events:none;opacity:0;transition:opacity 1.2s ease}#counter.show{opacity:1}#counter .label{font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--rose-gold);margin-bottom:4px;font-family:Helvetica Neue,sans-serif}#counter .time{font-size:22px;letter-spacing:2px;color:var(--cream);text-shadow:0 0 18px rgba(232,180,160,.5);font-family:Helvetica Neue,sans-serif;font-weight:300}#counter .badge{display:inline-block;margin-top:8px;padding:4px 16px;border:1px solid var(--rose-gold);border-radius:999px;font-size:12px;letter-spacing:3px;color:var(--blush);background:#b76e791f;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);text-transform:uppercase;font-family:Helvetica Neue,sans-serif}#progress{position:fixed;top:20px;left:22px;z-index:5;font-family:Helvetica Neue,sans-serif;font-size:11px;letter-spacing:2px;color:var(--rose-gold);text-transform:uppercase;opacity:0;transition:opacity 1s}#progress.show{opacity:.85}#progress b{color:var(--blush);font-weight:500}#musicPlayer{position:fixed;bottom:22px;right:22px;z-index:100;opacity:0;transform:translateY(20px);transition:opacity .8s ease,transform .8s ease;pointer-events:none;width:290px}#musicPlayer.show{opacity:1;transform:translateY(0);pointer-events:auto}.player-glow{position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:28px;background:radial-gradient(ellipse at 30% 50%,rgba(255,111,145,.22),transparent 70%);filter:blur(20px);z-index:-1;animation:playerGlow 4s ease-in-out infinite alternate}@keyframes playerGlow{0%{opacity:.5;transform:scale(.95)}to{opacity:1;transform:scale(1.05)}}.player-inner{background:linear-gradient(145deg,#2a1320e6,#1a0a14f2);border:1px solid rgba(232,180,160,.35);border-radius:24px;padding:16px 18px;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 12px 40px #000000a6,0 0 0 1px #ffc2d414 inset,0 1px #ffffff0d inset;display:flex;flex-direction:column}.vinyl-container{display:flex;align-items:center;justify-content:center;margin-bottom:12px;position:relative;height:74px}.vinyl-disc{width:70px;height:70px;border-radius:50%;background:radial-gradient(circle at 50% 50%,#0f050b,#1f0a17 25%,#0f050b 27%,#1a0813 45%,#0f050b 47%,#250f1d 65%,#0f050b 67%,#1d0b17);border:2px solid rgba(232,180,160,.3);display:flex;align-items:center;justify-content:center;box-shadow:0 0 20px #ff6f9133,0 4px 12px #00000080;transition:transform .3s ease;position:relative;overflow:hidden}.vinyl-disc.spinning{animation:spin 4s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.vinyl-groove{position:absolute;border-radius:50%;border:1px solid rgba(232,180,160,.06)}.vinyl-groove.v1{width:84%;height:84%}.vinyl-groove.v2{width:60%;height:60%}.vinyl-groove.v3{width:38%;height:38%}.vinyl-label{width:26px;height:26px;border-radius:50%;background:radial-gradient(circle,#ffa0b6,#b76e79);display:flex;align-items:center;justify-content:center;font-size:13px;z-index:2;box-shadow:0 0 10px #ffc2d466}.vinyl-arm{position:absolute;top:4px;right:44px;width:32px;height:3px;background:linear-gradient(90deg,#e6c79cb3,#e8b4a0f2);border-radius:2px;transform-origin:right center;transform:rotate(26deg);transition:transform .6s cubic-bezier(.25,1,.5,1);box-shadow:0 2px 4px #0000004d}.vinyl-arm:after{content:"";position:absolute;left:-2px;top:-1px;width:5px;height:5px;border-radius:50%;background:#e6c79cf2}.vinyl-arm.active{transform:rotate(10deg)}.player-info{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.song-details{flex:1;min-width:0}.song-title{font-family:Helvetica Neue,sans-serif;font-size:13px;font-weight:500;letter-spacing:1px;color:var(--cream);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.song-artist{font-family:Helvetica Neue,sans-serif;font-size:10px;letter-spacing:1px;color:var(--rose-gold);text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.waveform{display:flex;align-items:flex-end;gap:2px;height:18px;flex-shrink:0}.waveform span{width:3px;border-radius:2px;background:linear-gradient(to top,var(--rose-gold-2),var(--blush));height:4px;transition:height .15s ease}.waveform.active span{animation:wave .8s ease-in-out infinite}.waveform.active span:nth-child(1){animation-delay:0s}.waveform.active span:nth-child(2){animation-delay:.05s}.waveform.active span:nth-child(3){animation-delay:.1s}.waveform.active span:nth-child(4){animation-delay:.15s}.waveform.active span:nth-child(5){animation-delay:.2s}.waveform.active span:nth-child(6){animation-delay:.25s}.waveform.active span:nth-child(7){animation-delay:.3s}.waveform.active span:nth-child(8){animation-delay:.35s}.waveform.active span:nth-child(9){animation-delay:.4s}.waveform.active span:nth-child(10){animation-delay:.45s}.waveform.active span:nth-child(11){animation-delay:.5s}.waveform.active span:nth-child(12){animation-delay:.55s}.waveform.active span:nth-child(13){animation-delay:.6s}.waveform.active span:nth-child(14){animation-delay:.65s}.waveform.active span:nth-child(15){animation-delay:.7s}@keyframes wave{0%,to{height:4px}25%{height:16px}50%{height:7px}75%{height:18px}}.progress-wrap{display:flex;align-items:center;gap:8px;margin-bottom:12px}.time-readout{font-family:Helvetica Neue,sans-serif;font-size:9px;color:var(--rose-gold);width:26px;text-align:center}.progress-bar-container{flex:1;height:4px;background:#e8b4a026;border-radius:2px;cursor:pointer;position:relative;transition:height .2s ease}.progress-bar-container:hover{height:6px}.progress-bar-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--rose-gold-2),var(--blush));border-radius:2px;position:relative}.progress-bar-fill:after{content:"";position:absolute;right:-4px;top:50%;transform:translateY(-50%) scale(0);width:10px;height:10px;border-radius:50%;background:var(--cream);box-shadow:0 0 6px var(--blush);transition:transform .2s ease}.progress-bar-container:hover .progress-bar-fill:after{transform:translateY(-50%) scale(1)}.player-controls{display:flex;align-items:center;justify-content:space-between;gap:8px}.play-btn{width:38px;height:38px;flex-shrink:0;border-radius:50%;border:1px solid rgba(255,194,212,.45);background:linear-gradient(135deg,#ff6f9159,#b76e7940);color:var(--blush);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .25s ease;box-shadow:0 0 12px #ff6f9133}.play-btn:hover{transform:scale(1.1);background:linear-gradient(135deg,#ff6f9173,#b76e7959);box-shadow:0 0 20px #ff6f9173}.play-btn svg{width:18px;height:18px}.play-icon{margin-left:2px}.player-btn-secondary,.player-btn-nav,.vol-btn{width:28px;height:28px;border-radius:50%;border:1px solid rgba(232,180,160,.25);background:#ffc2d40d;color:var(--rose-gold);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.player-btn-secondary:hover,.player-btn-nav:hover,.vol-btn:hover{border-color:var(--blush);color:var(--blush);background:#ffc2d426;transform:scale(1.05)}.player-btn-secondary.active{background:#ff6f9133;border-color:var(--blush);color:var(--blush)}.volume-wrap{display:flex;align-items:center;gap:6px;flex-shrink:0}.volume-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:50px;height:3px;border-radius:2px;background:#e8b4a033;outline:none;cursor:pointer}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:10px;height:10px;border-radius:50%;background:var(--blush);box-shadow:0 0 6px #ffc2d499;cursor:pointer;transition:transform .15s}.volume-slider::-webkit-slider-thumb:hover{transform:scale(1.3)}.volume-slider::-moz-range-thumb{width:10px;height:10px;border-radius:50%;border:none;background:var(--blush);box-shadow:0 0 6px #ffc2d499;cursor:pointer}.playlist-drawer{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.25,1,.5,1),margin-top .4s ease,border-top .4s ease;border-top:1px solid transparent;margin-top:0}.playlist-drawer.open{max-height:240px;border-top:1px solid rgba(232,180,160,.25);margin-top:14px}.drawer-header{display:flex;justify-content:space-between;font-family:Helvetica Neue,sans-serif;font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--rose-gold);padding:10px 0 6px}.drawer-header .song-count{color:var(--gold);font-style:italic;text-transform:none;letter-spacing:0}.drawer-list{max-height:190px;overflow-y:auto;padding-right:4px}.drawer-list::-webkit-scrollbar{width:4px}.drawer-list::-webkit-scrollbar-track{background:#0000001a}.drawer-list::-webkit-scrollbar-thumb{background:var(--rose-gold-2);border-radius:2px}.drawer-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:background .2s ease,transform .1s ease;margin-bottom:4px}.drawer-item:hover{background:#ffc2d414;transform:translate(2px)}.drawer-item.active{background:#ff6f9126;border-left:3px solid var(--blush);padding-left:7px}.drawer-item .track-num{font-family:Helvetica Neue,sans-serif;font-size:10px;color:var(--rose-gold-2);width:14px;text-align:center}.drawer-item.active .track-num{color:var(--blush)}.drawer-item .track-details{flex:1;min-width:0}.drawer-item .track-title{font-family:Helvetica Neue,sans-serif;font-size:11px;font-weight:500;color:var(--cream);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:1px}.drawer-item.active .track-title{color:var(--blush);text-shadow:0 0 8px rgba(255,194,212,.3)}.drawer-item .track-artist{font-family:Helvetica Neue,sans-serif;font-size:9px;color:var(--rose-gold);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}#music{display:none!important}#dock{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:5;display:flex;gap:10px;padding:10px 14px;background:#1a0a1473;border:1px solid rgba(232,180,160,.25);border-radius:999px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:0;transition:opacity 1s;max-width:94vw;overflow-x:auto}#dock.show{opacity:1}.dock-btn{flex:0 0 auto;width:34px;height:34px;border-radius:50%;border:1px solid rgba(232,180,160,.4);background:#ffc2d414;color:var(--blush);cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;transition:all .25s;position:relative;font-family:Helvetica Neue,sans-serif}.dock-btn:hover{background:#ffc2d440;transform:translateY(-2px)}.dock-btn.visited{border-color:var(--gold);color:var(--gold)}.dock-btn.visited:after{content:"";position:absolute;top:-3px;right:-3px;width:8px;height:8px;background:var(--gold);border-radius:50%;box-shadow:0 0 6px var(--gold)}#dockHint{position:fixed;bottom:64px;left:50%;transform:translate(-50%);z-index:4;font-family:Helvetica Neue,sans-serif;font-size:10px;letter-spacing:2px;color:var(--rose-gold);text-transform:uppercase;opacity:0;transition:opacity 1s;pointer-events:none}#dockHint.show{opacity:.7}#card{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:none;align-items:center;justify-content:center;padding:24px;background:#0c05098c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}#card.show{display:flex;animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.card-inner{max-width:560px;width:100%;max-height:86vh;overflow-y:auto;background:linear-gradient(160deg,#3a1828f5,#1a0a14f7);border:1px solid rgba(232,180,160,.4);border-radius:22px;padding:38px 36px 30px;position:relative;box-shadow:0 30px 80px #0009,0 0 60px #e8b4a01f inset;animation:rise .6s cubic-bezier(.2,.8,.2,1)}@keyframes rise{0%{transform:translateY(30px) scale(.97);opacity:0}to{transform:none;opacity:1}}.card-inner::-webkit-scrollbar{width:6px}.card-inner::-webkit-scrollbar-thumb{background:var(--rose-gold-2);border-radius:3px}.card-month{font-family:Helvetica Neue,sans-serif;font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--rose-gold);margin-bottom:6px}.card-title{font-size:27px;line-height:1.2;color:var(--cream);margin-bottom:4px;text-shadow:0 0 24px rgba(255,194,212,.25)}.card-date{font-size:13px;color:var(--gold);font-style:italic;margin-bottom:18px}.card-body{font-size:16px;line-height:1.75;color:#f6e2df}.card-body p{margin-bottom:14px}.card-sign{margin-top:18px;text-align:right;color:var(--blush);font-style:italic;font-size:15px}.card-close{position:absolute;top:14px;right:16px;width:32px;height:32px;border-radius:50%;border:1px solid rgba(232,180,160,.4);background:transparent;color:var(--blush);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:background .2s}.card-close:hover{background:#b76e794d}.card-rose{text-align:center;font-size:26px;margin-bottom:10px}#intro{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:30px;background:radial-gradient(ellipse at center,#3a1828eb,#0c0509fa);transition:opacity 1.2s ease,visibility 1.2s}#intro.hide{opacity:0;visibility:hidden}#intro .rose-deco{font-size:52px;margin-bottom:18px;animation:floaty 4s ease-in-out infinite}@keyframes floaty{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}#intro h1{font-size:clamp(30px,6vw,54px);font-weight:400;letter-spacing:1px;background:linear-gradient(90deg,var(--blush),var(--gold),var(--rose-gold));-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:12px;line-height:1.15}#intro .sub{color:var(--blush-soft);font-size:15px;letter-spacing:1px;margin-bottom:6px}#intro .meta{color:var(--rose-gold);font-family:Helvetica Neue,sans-serif;font-size:12px;letter-spacing:3px;text-transform:uppercase;margin-bottom:34px}#enter{padding:14px 44px;border:1px solid var(--gold);border-radius:999px;background:linear-gradient(90deg,#b76e794d,#e6c79c40);color:var(--cream);font-family:Georgia,serif;font-size:17px;letter-spacing:2px;cursor:pointer;transition:all .3s;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}#enter:hover{transform:scale(1.05);box-shadow:0 0 40px #e8b4a066}#intro .hint{margin-top:26px;color:#ffe3ea80;font-family:Helvetica Neue,sans-serif;font-size:11px;letter-spacing:1px;line-height:1.7;max-width:320px}#toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%,20px);z-index:15;max-width:80vw;padding:14px 22px;border-radius:16px;background:linear-gradient(160deg,#3a1828f2,#1a0a14f7);border:1px solid rgba(230,199,156,.5);color:var(--cream);font-size:14px;line-height:1.5;text-align:center;opacity:0;pointer-events:none;transition:opacity .5s,transform .5s;box-shadow:0 10px 40px #00000080}#toast.show{opacity:1;transform:translate(-50%)}.mobile-only-progress{display:none;color:var(--blush);font-weight:500;margin-left:6px;font-size:11px}@media (max-width: 600px){#counter .time{font-size:15px}#counter .badge{padding:4px 14px;font-size:10px;letter-spacing:1px;display:inline-flex;align-items:center;justify-content:center}.mobile-only-progress{display:inline}#progress{display:none!important}.card-inner{padding:24px 18px 20px;max-height:90vh}.card-title{font-size:20px}.card-body{font-size:14px;line-height:1.65}#musicPlayer{bottom:85px;right:auto;left:50%;transform:translate(-50%,20px);width:calc(100% - 24px);max-width:330px}#musicPlayer.show{transform:translate(-50%)}.player-inner{display:grid;grid-template-columns:56px 1fr;column-gap:12px;row-gap:6px;padding:12px 14px;align-items:center}.vinyl-container{grid-column:1;grid-row:1 / span 2;height:56px;width:56px;margin-bottom:0;align-self:center}.vinyl-disc{width:56px;height:56px;box-shadow:0 0 12px #ff6f9126}.vinyl-arm{display:none!important}.vinyl-label{width:20px;height:20px;font-size:10px}.player-info{grid-column:2;grid-row:1;margin-bottom:0;display:flex;justify-content:space-between;align-items:center}.song-title{font-size:12px}.waveform{height:14px;gap:1px}.waveform span{width:2px;height:3px}.progress-wrap{grid-column:1 / span 2;grid-row:3;margin-bottom:0;margin-top:4px}.time-readout{font-size:8px;width:22px}.player-controls{grid-column:2;grid-row:2;display:flex;align-items:center;justify-content:flex-start;gap:8px}.play-btn{width:32px;height:32px}.play-btn svg{width:14px;height:14px}.player-btn-secondary,.player-btn-nav,.vol-btn{width:26px;height:26px}.player-btn-secondary svg,.player-btn-nav svg,.vol-btn svg{width:13px;height:13px}.volume-wrap{display:none!important}.playlist-drawer{grid-column:1 / span 2;grid-row:4}.playlist-drawer.open{max-height:180px;margin-top:8px}.drawer-list{max-height:140px}#dock{bottom:15px;gap:8px;padding:8px 12px}.dock-btn{width:32px;height:32px;font-size:11px}#dockHint{bottom:70px;font-size:9px}}
