:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;--color-bg:#ebe8e3;--color-bg-elevated:#f7f5f2;--color-surface:#fff;--color-surface-muted:#faf9f7;--color-ink:#14121a;--color-ink-muted:#5c5666;--color-ink-faint:#8a8494;--color-border:#14121a1a;--color-border-strong:#14121a29;--color-accent:#e11d48;--color-accent-hover:#be123c;--color-accent-soft:#e11d481f;--color-teal:#0d9488;--color-teal-soft:#0d94881f;--color-danger-bg:#fff1f2;--color-danger-border:#fecdd3;--color-danger-text:#9f1239;--font-display:"Fraunces", ui-serif, Georgia, serif;--font-body:"Outfit", system-ui, sans-serif;--font-mono:ui-monospace, "Cascadia Code", "Source Code Pro", Menlo, monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-hero:clamp(2rem, 5vw, 2.75rem);--leading-tight:1.2;--leading-snug:1.35;--leading-normal:1.5;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--shadow-sm:0 1px 2px #14121a0d;--shadow-md:0 4px 14px #14121a12, 0 1px 3px #14121a0a;--shadow-lg:0 12px 40px #14121a1a, 0 2px 8px #14121a0d;--shadow-inset:inset 0 1px 0 #ffffffa6;--focus-ring:0 0 0 2px var(--color-bg-elevated), 0 0 0 4px var(--color-accent);--focus-ring-inset:inset 0 0 0 2px var(--color-accent);--ease-out:cubic-bezier(.22, 1, .36, 1);--duration-fast:.15s;--heatmap-empty:#e4e2de;--heatmap-0:#e4e2de;--heatmap-10:#cfe8e5;--heatmap-20:#b9ddd9;--heatmap-30:#a3d2cd;--heatmap-40:#8dc7c1;--heatmap-50:#77bcb5;--heatmap-60:#61b1a9;--heatmap-70:#4ba69d;--heatmap-80:#359b91;--heatmap-90:#1f9085;--heatmap-100:#0d9488;--chart-line-play:#fb7e2a;--chart-line-skip:#6db99a;--chart-fill-play:#fb7e2a2e;--chart-fill-skip:#6db99a2e;--chart-point-bg:#fffffff2;--chart-point-border:#fff;--chart-point-hover-bg:#fff;--chart-point-hover-border:#ffffffd9;--color-on-accent:#fff;--color-share-btn-bg:#14121a;--color-share-btn-fg:#fff;--color-share-btn-hover:#2d2a35}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial;--color-bg:#16141a;--color-bg-elevated:#1e1c24;--color-surface:#26232c;--color-surface-muted:#201e26;--color-ink:#f4f1f8;--color-ink-muted:#a39aad;--color-ink-faint:#756d82;--color-border:#f4f1f81a;--color-border-strong:#f4f1f829;--color-accent:#fb7185;--color-accent-hover:#f43f5e;--color-accent-soft:#fb718524;--color-teal:#2dd4bf;--color-teal-soft:#2dd4bf1f;--color-danger-bg:#3b121c;--color-danger-border:#881337;--color-danger-text:#fecdd3;--shadow-sm:0 1px 2px #00000059;--shadow-md:0 4px 14px #00000073, 0 1px 3px #00000059;--shadow-lg:0 12px 40px #0000008c, 0 2px 8px #0006;--shadow-inset:inset 0 1px 0 #ffffff0f;--focus-ring:0 0 0 2px var(--color-bg-elevated), 0 0 0 4px var(--color-accent);--heatmap-empty:#2a2730;--heatmap-0:#2a2730;--heatmap-10:#234a45;--heatmap-20:#1f5f56;--heatmap-30:#1b7267;--heatmap-40:#178578;--heatmap-50:#149889;--heatmap-60:#11ab9a;--heatmap-70:#0ebeab;--heatmap-80:#0bd1bc;--heatmap-90:#08e4cd;--heatmap-100:#2dd4bf;--chart-line-play:#ffa14a;--chart-line-skip:#7dccb0;--chart-fill-play:#ffa14a33;--chart-fill-skip:#7dccb033;--chart-point-bg:#26232cf2;--chart-point-border:#f4f1f8;--chart-point-hover-bg:#f4f1f8;--chart-point-hover-border:#f4f1f8d9;--color-on-accent:#fff;--color-share-btn-bg:#3a3644;--color-share-btn-fg:#f4f1f8;--color-share-btn-hover:#4a4558}}*,:before,:after{box-sizing:border-box}body{font-family:var(--font-body);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-ink);background-color:var(--color-bg);background-image:radial-gradient(ellipse 120% 80% at 50% -20%, color-mix(in srgb, var(--color-accent) 14%, transparent), transparent 55%);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0}code{font-family:var(--font-mono);font-size:.9em}:focus{outline:none}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{box-shadow:var(--focus-ring)}.inputfile:focus-visible+label{box-shadow:var(--focus-ring);outline:none}.App{max-width:72rem;padding:var(--space-4) var(--space-4) var(--space-10);margin-inline:auto}.App a{color:var(--color-accent);text-underline-offset:3px;transition:color var(--duration-fast) var(--ease-out);text-decoration-thickness:1px}.App a:hover{color:var(--color-accent-hover)}.App h1,.App h2,.App h3,.App h4,.App h5,.App h6{font-family:var(--font-display);font-weight:600;line-height:var(--leading-tight);color:var(--color-ink)}.App h1.display-3{font-size:var(--text-hero);letter-spacing:-.03em;margin-bottom:var(--space-4);font-weight:700}.App .lead{font-family:var(--font-body);font-size:var(--text-lg);line-height:var(--leading-snug);color:var(--color-ink-muted);font-weight:400}.App hr{height:1px;margin:var(--space-5) 0;background:linear-gradient(90deg, transparent, var(--color-border-strong) 15%, var(--color-border-strong) 85%, transparent);border:none}.box{box-shadow:var(--shadow-md), var(--shadow-inset);padding:var(--space-6);background-color:var(--color-surface);margin:var(--space-4);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.hero{background:linear-gradient(145deg, var(--color-surface) 0%, var(--color-surface-muted) 48%, #e11d480a 100%);border-radius:var(--radius-xl);margin:var(--space-4);padding:var(--space-8) var(--space-6);box-shadow:var(--shadow-lg);border:1px solid var(--color-border);position:relative;overflow:hidden}.hero:before{content:"";background:radial-gradient(ellipse 70% 50% at 100% 0%, var(--color-accent-soft), transparent 55%);pointer-events:none;position:absolute;inset:0}.hero>*{z-index:1;position:relative}.hero.hero--intro{padding:var(--space-10) var(--space-6)}.hero.hero--dashboard{padding:var(--space-6)}.year{background-color:var(--color-surface);width:300px;min-height:300px;margin:var(--space-4);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-md);transition:transform var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out);flex-direction:column;justify-content:space-between;display:flex}.year:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.years{flex-wrap:wrap;justify-content:flex-start;display:flex}.linechart{margin:var(--space-4);width:min(650px,100%);max-width:100%}.reasons{flex-wrap:wrap;justify-content:flex-start;display:flex}.reason{background-color:var(--color-surface-muted);margin:var(--space-2);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);border-radius:var(--radius-md)}.totals{margin:var(--space-4)}.box .lead,.box .h1,.box .h2,.box .h3,.box .h4,.box .h5,.box .h6,.box h1,.box h2,.box h3,.box h4,.box h5,.box h6{margin-bottom:0}.title-flex{margin-bottom:var(--space-5);justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.App .btn{font-family:var(--font-body);font-weight:600;font-size:var(--text-sm);border-radius:var(--radius-md);padding:var(--space-2) var(--space-4);transition:background-color var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out)}.App .btn.btn-outline-secondary{color:var(--color-ink);border:1px solid var(--color-border-strong);background:var(--color-surface)}.App .btn.btn-outline-secondary:hover:not(:disabled){border-color:var(--color-ink-muted);background:var(--color-surface-muted);color:var(--color-ink)}.App .btn.btn-outline-secondary.active,.App .btn.btn-outline-secondary:active{border-color:var(--color-accent);background:var(--color-accent-soft);color:var(--color-accent-hover)}.App .btn.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}.errorDiv{border:1px solid var(--color-danger-border);background:var(--color-danger-bg);color:var(--color-danger-text);border-radius:var(--radius-lg)}.errorDiv a{color:var(--color-danger-text);font-weight:600}.errorDiv .btn{margin-top:var(--space-3)}.all-songs-table .table-filters{gap:var(--space-4);margin-bottom:var(--space-4);flex-wrap:wrap;display:flex}.all-songs-table .filter-field{gap:var(--space-2);flex-direction:column;min-width:220px;display:flex}.all-songs-table .filter-field label{font-size:var(--text-sm);color:var(--color-ink-muted);font-weight:600}.all-songs-table .filter-field input{padding:var(--space-3) var(--space-3);border-radius:var(--radius-md);border:1px solid var(--color-border-strong);font-family:var(--font-body);font-size:var(--text-sm);background:var(--color-surface);color:var(--color-ink);transition:border-color var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out)}.all-songs-table .filter-field input::placeholder{color:var(--color-ink-faint)}.all-songs-table .filter-field input:hover{border-color:var(--color-ink-faint)}.all-songs-table .table-wrapper{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);overflow-x:auto}.all-songs-table table{border-collapse:collapse;width:100%;min-width:720px}.all-songs-table th,.all-songs-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);vertical-align:middle;font-size:var(--text-sm)}.all-songs-table th{background:var(--color-surface-muted);text-align:left;color:var(--color-ink-muted);font-weight:600}.all-songs-table tr:hover td{background:#0d94880f}.all-songs-table .align-right{text-align:right}.all-songs-table .align-center{text-align:center}.all-songs-table .table-sort-button{align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);margin:calc(-1 * var(--space-1)) calc(-1 * var(--space-2));font:inherit;cursor:pointer;color:var(--color-ink);border-radius:var(--radius-sm);transition:background-color var(--duration-fast) var(--ease-out);background:0 0;border:none;font-weight:600;display:inline-flex}.all-songs-table .table-sort-button:hover{background:#14121a0d}.all-songs-table .sort-indicator{color:var(--color-accent);font-size:.85em;font-weight:700}.all-songs-table .empty-state{text-align:center;padding:var(--space-8) var(--space-4);color:var(--color-ink-muted)}.all-songs-table .table-pagination{justify-content:space-between;align-items:center;gap:var(--space-4);margin-top:var(--space-4);font-size:var(--text-sm);color:var(--color-ink-muted);flex-wrap:wrap;display:flex}.all-songs-table .pagination-controls{gap:var(--space-2);display:flex}.all-songs-table .pagination-controls button{font-family:var(--font-body);font-weight:600;font-size:var(--text-sm);border:1px solid var(--color-border-strong);background:var(--color-surface);color:var(--color-ink);border-radius:var(--radius-md);padding:var(--space-2) var(--space-4);cursor:pointer;transition:background-color var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out)}.all-songs-table .pagination-controls button:hover:not(:disabled){background:var(--color-surface-muted);border-color:var(--color-ink-muted)}.all-songs-table .pagination-controls button:disabled{opacity:.45;cursor:not-allowed}.collapse-panel{opacity:0;max-height:0;transition:max-height .3s var(--ease-out), opacity .2s var(--ease-out);overflow:hidden}.collapse-panel.is-open{opacity:1;max-height:2000px}.collapse-panel__content{padding-top:var(--space-2)}.artists .year{min-height:min-intrinsic}.footer{opacity:1;margin:var(--space-8) var(--space-4) var(--space-4);padding-top:var(--space-6);border-top:1px solid var(--color-border);font-size:var(--text-sm);color:var(--color-ink-muted);line-height:var(--leading-snug);text-align:center}.footer a{color:var(--color-ink);font-weight:600}.inputfile+label{cursor:pointer;display:inline-block}.calendar-heatmap{align-items:flex-start;gap:var(--space-3);display:flex}.calendar-heatmap__weekday-labels{font-size:var(--text-xs);color:var(--color-ink-muted);flex-direction:column;gap:4px;padding-top:2px;display:flex}.calendar-heatmap__grid{gap:4px;padding-bottom:4px;display:flex;overflow-x:auto}.calendar-heatmap__week{flex-direction:column;gap:4px;display:flex}.calendar-heatmap__day{background-color:var(--heatmap-empty);border-radius:3px;width:12px;height:12px}.calendar-heatmap .color-empty{background-color:var(--heatmap-empty)}.calendar-heatmap .color-scale-0{background-color:var(--heatmap-0)}.calendar-heatmap .color-scale-10{background-color:var(--heatmap-10)}.calendar-heatmap .color-scale-20{background-color:var(--heatmap-20)}.calendar-heatmap .color-scale-30{background-color:var(--heatmap-30)}.calendar-heatmap .color-scale-40{background-color:var(--heatmap-40)}.calendar-heatmap .color-scale-50{background-color:var(--heatmap-50)}.calendar-heatmap .color-scale-60{background-color:var(--heatmap-60)}.calendar-heatmap .color-scale-70{background-color:var(--heatmap-70)}.calendar-heatmap .color-scale-80{background-color:var(--heatmap-80)}.calendar-heatmap .color-scale-90{background-color:var(--heatmap-90)}.calendar-heatmap .color-scale-100{background-color:var(--heatmap-100)}.sk-fading-circle{margin:var(--space-10) auto;width:40px;height:40px;position:relative}.sk-fading-circle .sk-circle{width:100%;height:100%;position:absolute;top:0;left:0}.sk-fading-circle .sk-circle:before{content:"";background-color:var(--color-accent);border-radius:100%;width:15%;height:15%;margin:0 auto;animation:1.2s ease-in-out infinite both sk-circleFadeDelay;display:block}.sk-fading-circle .sk-circle2{transform:rotate(30deg)}.sk-fading-circle .sk-circle3{transform:rotate(60deg)}.sk-fading-circle .sk-circle4{transform:rotate(90deg)}.sk-fading-circle .sk-circle5{transform:rotate(120deg)}.sk-fading-circle .sk-circle6{transform:rotate(150deg)}.sk-fading-circle .sk-circle7{transform:rotate(180deg)}.sk-fading-circle .sk-circle8{transform:rotate(210deg)}.sk-fading-circle .sk-circle9{transform:rotate(240deg)}.sk-fading-circle .sk-circle10{transform:rotate(270deg)}.hour-heatmap{gap:var(--space-2);flex-direction:column;display:flex}.heatmap-header{grid-template-columns:60px 1fr;align-items:center;display:grid}.heatmap-x-labels{color:var(--color-ink-muted);grid-template-columns:repeat(24,minmax(20px,1fr));gap:4px;font-size:.7rem;display:grid}.heatmap-y-spacer{height:1.5rem}.heatmap-body{flex-direction:column;gap:6px;display:flex}.heatmap-row{grid-template-columns:60px 1fr;align-items:center;gap:8px;display:grid}.heatmap-y-label{color:var(--color-ink-muted);font-size:.8rem}.heatmap-cells{grid-template-columns:repeat(24,minmax(20px,1fr));gap:4px;display:grid}.heatmap-cell{border-radius:var(--radius-sm);height:20px}.sk-fading-circle .sk-circle11{transform:rotate(300deg)}.sk-fading-circle .sk-circle12{transform:rotate(330deg)}.sk-fading-circle .sk-circle2:before{animation-delay:-1.1s}.sk-fading-circle .sk-circle3:before{animation-delay:-1s}.sk-fading-circle .sk-circle4:before{animation-delay:-.9s}.sk-fading-circle .sk-circle5:before{animation-delay:-.8s}.sk-fading-circle .sk-circle6:before{animation-delay:-.7s}.sk-fading-circle .sk-circle7:before{animation-delay:-.6s}.sk-fading-circle .sk-circle8:before{animation-delay:-.5s}.sk-fading-circle .sk-circle9:before{animation-delay:-.4s}.sk-fading-circle .sk-circle10:before{animation-delay:-.3s}.sk-fading-circle .sk-circle11:before{animation-delay:-.2s}.sk-fading-circle .sk-circle12:before{animation-delay:-.1s}@keyframes sk-circleFadeDelay{0%,39%,to{opacity:0}40%{opacity:1}}.wrapped{background-color:var(--color-accent);padding:var(--space-8);border-radius:var(--radius-lg);width:700px;max-width:100%;color:var(--color-on-accent);box-shadow:var(--shadow-lg);background-image:url(/background.jpg);background-repeat:repeat;background-size:50%;display:block}.wrapped .title{width:100%}.wrapped .wrapped-content{flex-wrap:wrap;justify-content:space-between;width:100%;display:flex}.wrapped .number{font-size:4em;line-height:.9;font-family:var(--font-display);font-weight:700}.wrapped h2,.wrapped h3,.wrapped div{margin:0;padding:0}.wrapped .subtitle{text-transform:uppercase;font-size:var(--text-sm);padding-top:var(--space-5);letter-spacing:.08em;opacity:.95;font-weight:500}.wrapped .small{margin-top:var(--space-3)}.wrapped .item{font-weight:600}.wrapped .artist{opacity:.75;font-weight:400}.wrapped img{max-width:150px;margin-top:var(--space-4)}.shareButton{margin:var(--space-4) 0 0}.shareButton button{font-family:var(--font-body);font-weight:600;font-size:var(--text-sm);color:var(--color-share-btn-fg);background:var(--color-share-btn-bg);border-radius:var(--radius-md);padding:var(--space-3) var(--space-5);cursor:pointer;box-shadow:var(--shadow-md);transition:transform var(--duration-fast) var(--ease-out), background-color var(--duration-fast) var(--ease-out);border:none}.shareButton button:hover{background:var(--color-share-btn-hover);transform:translateY(-1px)}.upload-controls{margin-bottom:var(--space-5)}.upload-controls p{color:var(--color-ink-muted);max-width:42rem}.upload-controls__date-label{margin-top:var(--space-3);font-weight:600;font-size:var(--text-sm);color:var(--color-ink);display:block}.date-input{margin-top:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1px solid var(--color-border-strong);font-family:var(--font-body);font-size:var(--text-sm);background:var(--color-surface);color:var(--color-ink);display:block}.resolve-artists-option{margin-top:var(--space-4);max-width:42rem;padding:var(--space-3);border-radius:var(--radius-md);background:var(--color-teal-soft);border:1px solid #0d948833}.resolve-artists-option__label{align-items:flex-start;gap:var(--space-3);font-weight:400;font-size:var(--text-sm);line-height:var(--leading-normal);color:var(--color-ink-muted);cursor:pointer;margin:0;display:flex}.resolve-artists-option__label input[type=checkbox]{width:1.125rem;height:1.125rem;accent-color:var(--color-teal);cursor:pointer;flex:none;margin:.2em 0 0}.resolve-artists-option__label:has(input:disabled){cursor:not-allowed;opacity:.75}.resolve-artists-option__text{flex:auto;min-width:0}.file-input-wrap{margin:var(--space-4) 0}.file-label{padding:var(--space-3) var(--space-6);background:linear-gradient(135deg, var(--color-accent) 0%, var(--color-accent-hover) 100%);color:var(--color-on-accent);border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:var(--text-sm);letter-spacing:.02em;box-shadow:var(--shadow-md);transition:transform var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out);border:none;display:inline-block}.file-label:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}.inputfile{clip:rect(0, 0, 0, 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.status-text{min-height:1.5em;color:var(--color-ink-muted);font-size:var(--text-sm)}.load-error{margin:var(--space-4)}.loading-panel{margin:var(--space-8) auto}.loading-panel h4{font-family:var(--font-display);color:var(--color-ink-muted)}.chart-box{overflow-x:auto}.wrapped-box{max-width:calc(2em + 700px)}.top-song-box{min-height:12rem}.box a img{border-radius:var(--radius-md);box-shadow:var(--shadow-sm);vertical-align:middle}.box pre{font-size:var(--text-xs);padding:var(--space-3) var(--space-4);background:var(--color-surface-muted);border-radius:var(--radius-md);border:1px solid var(--color-border);overflow-x:auto}@media (width<=768px){.App{padding:var(--space-3) var(--space-3) var(--space-8)}.year{width:100%;max-width:100%;min-height:auto}.box h1.display-3{font-size:1.85rem}.title-flex{align-items:stretch;gap:var(--space-3);flex-direction:column}.hero{padding:var(--space-6) var(--space-4);margin:var(--space-2);border-radius:var(--radius-lg)}.hero.hero--intro{padding:var(--space-8) var(--space-4)}.box{margin:var(--space-2);padding:var(--space-4)}.wrapped{width:100%;padding:var(--space-5)}.all-songs-table .filter-field{min-width:100%}}@media (width<=480px){.App h1.display-3{font-size:1.65rem}.all-songs-table .table-pagination{flex-direction:column;align-items:stretch}.all-songs-table .pagination-controls{justify-content:stretch}.all-songs-table .pagination-controls button{flex:1}}
