.react-calendar-heatmap text{font-size:10px;fill:#aaa}.react-calendar-heatmap .react-calendar-heatmap-small-text{font-size:5px}.react-calendar-heatmap rect:hover{stroke:#555;stroke-width:1px}.react-calendar-heatmap .color-empty{fill:#eee}.react-calendar-heatmap .color-filled{fill:#8cc665}.react-calendar-heatmap .color-github-0{fill:#eee}.react-calendar-heatmap .color-github-1{fill:#d6e685}.react-calendar-heatmap .color-github-2{fill:#8cc665}.react-calendar-heatmap .color-github-3{fill:#44a340}.react-calendar-heatmap .color-github-4{fill:#1e6823}.react-calendar-heatmap .color-gitlab-0{fill:#ededed}.react-calendar-heatmap .color-gitlab-1{fill:#acd5f2}.react-calendar-heatmap .color-gitlab-2{fill:#7fa8d1}.react-calendar-heatmap .color-gitlab-3{fill:#49729b}.react-calendar-heatmap .color-gitlab-4{fill:#254e77}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background:#2c222c;border-radius:12px;padding:2rem;width:90%;max-width:650px;max-height:50vh;overflow-y:auto;position:relative;box-shadow:0 4px 6px #0000001a;color:#fff}.track-card{display:flex;align-items:center;background:#333;padding:.75rem;border-radius:6px}.track-info{display:flex;flex-direction:column}.close-button{margin-top:1rem;background:#444;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer}.spinner{border:6px solid #f3f3f3;border-top:6px solid #9147ff;border-radius:50%;width:48px;height:48px;animation:spin 1s linear infinite;margin-bottom:1rem}.stats-container{display:flex;justify-content:space-around;gap:2rem;margin-top:2rem;flex-wrap:wrap}.stat-card{background-color:#111;color:#fff;border-radius:10px;padding:1rem;width:300px;max-height:700px;overflow-y:auto;box-shadow:0 0 40px #9147ff66;border:1px solid rgba(145,71,255,.2)}.stat-card.songs-card{width:400px;max-height:500px;box-shadow:0 0 40px #9147ff66;border:1px solid rgba(145,71,255,.2);margin-top:2.5rem}.stat-card h3{text-align:center;margin-bottom:1rem;font-size:1.2rem;color:#e0e0e0}.stat-list{list-style:none;padding:0;margin:0}.stat-item{padding:.5rem 0;border-bottom:1px solid #222;font-size:.95rem}.stat-item:last-child{border-bottom:none}.rank{font-weight:700;margin-right:.5rem;color:#5e00b6}.metric-toggle{display:flex;justify-content:center;gap:1rem;margin-bottom:1.5rem}.metric-toggle button{padding:.45rem 1.3rem;font-size:1rem;border-radius:999px;border:1.5px solid #3a2a5d;background:#1e003c26;color:#e0e0e0;cursor:pointer;transition:background .22s cubic-bezier(.4,0,.2,1),color .22s cubic-bezier(.4,0,.2,1),box-shadow .22s cubic-bezier(.4,0,.2,1),transform .13s cubic-bezier(.4,0,.2,1);box-shadow:none;outline:none;margin-bottom:.1rem}.metric-toggle button.active{background:linear-gradient(90deg,#9147ff,#5e00b6);color:#fff;border-color:#9147ff;box-shadow:0 2px 12px #9147ff2e;font-weight:600}.metric-toggle button:hover:not(.active){background:#9147ff1a;color:#fff;border-color:#5e00b6;transform:scale(1.04)}.metric-toggle button:active{transform:scale(.97)}.stat-item .value{float:right;font-weight:500;color:#ccc}.stat-header{display:flex;justify-content:space-between;align-items:center}.metric-toggle{display:flex;gap:.5rem}.metric-toggle button{padding:.3rem .6rem;font-size:.8rem;border-radius:6px;border:1px solid #333;background-color:#111;color:#fff;cursor:pointer}.metric-toggle button.active{background-color:#5e00b6;color:#fff;border-color:#5e00b6}.track-list{display:flex;flex-direction:column;gap:1rem}.track-card{display:flex;align-items:center;background:#1a1a1a;padding:.75rem;border-radius:6px}.track-image{width:64px;height:64px;object-fit:cover;border-radius:4px;margin-right:1rem}.track-info{display:flex;flex-direction:column;flex:1}.track-title{font-weight:700;font-size:1rem}.track-artist{font-size:.9rem;color:#ccc}.track-value{font-size:.9rem;color:#e0e0e0;font-weight:700;margin-top:.25rem}.loading-container{display:flex;flex-direction:column;align-items:center;padding:2rem}.spinner{border:6px solid #f3f3f3;border-top:6px solid #5e00b6;border-radius:50%;width:48px;height:48px;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.alltime-tab-bar{display:flex;justify-content:center;gap:.5rem;margin-bottom:.5rem}.alltime-tab-bar button{padding:.45rem 1.3rem;font-size:1rem;border-radius:999px;border:1.5px solid #3a2a5d;background:#1e003c26;color:#e0e0e0;cursor:pointer;transition:background .22s cubic-bezier(.4,0,.2,1),color .22s cubic-bezier(.4,0,.2,1),box-shadow .22s cubic-bezier(.4,0,.2,1),transform .13s cubic-bezier(.4,0,.2,1);box-shadow:none;outline:none;margin-bottom:.1rem}.alltime-tab-bar button.tab-active{background:linear-gradient(90deg,#9147ff,#5e00b6);color:#fff;border-color:#9147ff;box-shadow:0 2px 12px #9147ff2e;font-weight:600}.alltime-tab-bar button:hover:not(.tab-active){background:#9147ff1a;color:#fff;border-color:#5e00b6;transform:scale(1.04)}.alltime-tab-bar button:active{transform:scale(.97)}.alltime-header{text-align:center;margin-bottom:1.2rem}.alltime-title{font-size:2rem;font-weight:700;margin:0;color:#fff;letter-spacing:.5px}.alltime-subtext{font-size:1.05rem;color:#baf;margin-top:.3rem;font-weight:400}.track-rank-badge{min-width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:600;color:#baf;background:transparent;border-radius:4px;margin-right:1rem;border:1px solid rgba(145,71,255,.3);flex-shrink:0}.chatbot-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0f0f2380;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);z-index:2000}.chatbot-modal{position:fixed;top:0;right:0;width:30vw;min-width:340px;max-width:450px;height:100vh;background:#0f0f23cc;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-top-left-radius:12px;border-bottom-left-radius:12px;box-shadow:-2px 0 32px #0003;border-left:1px solid rgba(145,71,255,.2);display:flex;flex-direction:column;z-index:2001;animation:chatbot-slide-in .22s cubic-bezier(.4,0,.2,1)}@keyframes chatbot-slide-in{0%{right:-40vw;opacity:0}to{right:0;opacity:1}}.chatbot-header-modal{display:flex;align-items:center;justify-content:center;padding:1rem 1.5rem;font-size:1.2rem;font-weight:600;color:#fff;background:transparent;border-top-left-radius:12px;border-bottom:1px solid rgba(145,71,255,.2);position:relative}.chatbot-close-btn{background:none;border:none;color:#a0a0a0;font-size:1.8rem;font-weight:300;cursor:pointer;position:absolute;right:1.2rem;top:50%;transform:translateY(-50%);transition:all .3s ease;z-index:1}.chatbot-close-btn:hover{color:#fff;transform:translateY(-50%) scale(1.1)}.chatbot-container{display:none}.chatbot-container{display:flex;flex-direction:column;background:#000;border-radius:14px;box-shadow:0 0 40px #9147ff2e;border:1px solid rgba(145,71,255,.13);width:400px;max-width:100%;height:600px;margin-left:0;margin-top:2.5rem}.chatbot-header{padding:1.1rem 1.5rem .7rem;font-size:1.35rem;font-weight:700;color:#fff;border-bottom:1px solid #23234a;letter-spacing:.2px;background:#23232a;border-top-left-radius:14px;border-top-right-radius:14px}.chatbot-messages{flex:1 1 0%;overflow-y:auto;padding:1.2rem;display:flex;flex-direction:column;gap:.7rem;background:transparent;min-height:0}.chatbot-bubble{max-width:80%;padding:.8rem 1.2rem;border-radius:18px;font-size:.95rem;line-height:1.5;word-break:break-word;box-shadow:0 2px 8px #9147ff12}.chatbot-bubble-user{align-self:flex-end;background:#9146ff33;border:1px solid rgba(145,70,255,.3);color:#e6daff;border-bottom-right-radius:6px}.chatbot-bubble-bot{align-self:flex-start;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#a0a0a0;border-bottom-left-radius:6px}.chatbot-input-bar{display:flex;align-items:center;padding:.8rem 1.2rem;border-top:1px solid rgba(145,71,255,.2);background:transparent}.chatbot-input{flex:1;padding:.8rem 1.2rem;border-radius:8px;border:1px solid rgba(145,70,255,.3);background:#9146ff1a;color:#fff;font-size:.95rem;outline:none;margin-right:.8rem;transition:all .3s ease}.chatbot-input:focus{border-color:#9146ff;box-shadow:0 0 0 2px #9146ff33}.chatbot-send-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid rgba(145,70,255,.3);background:#9146ff1a;cursor:pointer;transition:all .3s ease}.chatbot-send-btn:hover{background:#9146ff33;border-color:#9146ff80}.chatbot-send-btn svg{width:20px;height:20px}.chatbot-send-btn svg path{stroke:#c5a8ff;transition:stroke .3s ease}.chatbot-send-btn:hover svg path{stroke:#e6daff}.navbar{position:fixed;top:0;left:0;width:100vw;height:60px;background:#0f0f23cc;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;z-index:1000;border-bottom:1px solid rgba(145,71,255,.2)}.navbar-inner{height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 1.2rem 0 2.5rem}.navbar-year-select{margin-left:1rem;padding:.4rem .8rem;border-radius:6px;border:1px solid rgba(145,71,255,.3);background:#9146ff1a;color:#fff;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease}.navbar-year-select:hover{border-color:#9147ff80;background:#9146ff26}.navbar-year-select:focus{outline:none;border-color:#9146ff;box-shadow:0 0 0 2px #9146ff33}.navbar-title{font-size:1.35rem;font-weight:700;letter-spacing:.5px;flex:1;text-align:left}.navbar-buttons{display:flex;align-items:center;gap:1rem}.navbar-clear-btn,.navbar-chatbot-btn{padding:.5rem 1.2rem;border-radius:8px;border:1px solid transparent;background:transparent;color:#a0a0a0;font-weight:500;font-size:.9rem;cursor:pointer;transition:all .3s ease}.navbar-clear-btn:hover{background:#ff47471a;border-color:#ff47474d;color:#ff4747}.navbar-chatbot-btn{background:#9146ff1a;border-color:#9146ff4d;color:#c5a8ff}.navbar-chatbot-btn:hover{background:#9146ff33;border-color:#9146ff80;color:#e6daff}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.color-white{fill:#fff}.color-purple-light{fill:#d6b3ff}.color-purple-mid{fill:#9147ff}.color-purple-dark{fill:#5e00b6}.color-max{fill:#3a0080}.react-calendar-heatmap rect{rx:2px;ry:2px;stroke:#1e1e1e;stroke-width:2px}.react-calendar-heatmap text{font-size:9px;fill:#796e6e}.react-calendar-heatmap .weekday{display:block!important}.heatmap-legend{display:flex;flex-direction:row;align-items:center;gap:.4rem;font-size:.85rem;color:#ccc;margin-top:.5rem;margin-bottom:1rem;justify-content:flex-start}.legend-box{width:14px;height:14px;border-radius:2px;border:1px solid #333;flex-shrink:0}.legend-box.color-white{background-color:#fff}.legend-box.color-purple-light{background-color:#d6b3ff}.legend-box.color-purple-mid{background-color:#9147ff}.legend-box.color-purple-dark{background-color:#5e00b6}.legend-box.color-max{background-color:#3a0080}
