@import "https://fonts.googleapis.com/css2?family=Sora&display=swap";@import "https://fonts.googleapis.com/css2?family=Limelight&display=swap";:root{--bg-base:#02213f;--bg-surface:#08101a;--bg-elevated:#033769;--bg-highlight:#03437e;--accent:#319afa;--accent-hover:#75bcff;--accent-dim:#1db9541f;--text-primary:#dfe7ed;--text-secondary:#b6dbfd;--text-muted:#6c98c1;--border:#ffffff12;--border-hover:#ffffff24;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--shadow:0 4px 24px #00000080;--font:"Sora", -apple-system, BlinkMacSystemFont, sans-serif;--font-title:"Limelight", -apple-system, BlinkMacSystemFont, sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg-base);color:var(--text-primary);font-family:var(--font);-webkit-font-smoothing:antialiased;min-height:100vh;font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}.spinner{border:2px solid #fff3;border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.6s linear infinite spin;display:inline-block}.spinner--lg{border-width:3px;width:32px;height:32px}@keyframes spin{to{transform:rotate(360deg)}}.fullpage-state{flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:100vh;padding:2rem;display:flex}.state-message{color:var(--text-secondary);font-size:1rem}.state-error{color:#f55;text-align:center;font-size:1rem}.btn-primary{background:var(--accent);color:var(--bg-surface);cursor:pointer;border:none;border-radius:500px;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.75rem 1.5rem;font-size:.9rem;font-weight:400;transition:background .15s,opacity .15s,transform .1s;display:inline-flex}.btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:scale(1.01)}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-share{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border);cursor:pointer;border-radius:500px;align-items:center;gap:.4rem;padding:.45rem 1rem;font-size:.8rem;font-weight:600;transition:background .15s,border-color .15s;display:inline-flex}.btn-share:hover{background:var(--bg-highlight);border-color:var(--border-hover)}.top-bar{z-index:100;background:var(--accent);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);font-family:var(--font-title);justify-content:space-between;align-items:center;padding:.75rem 1.5rem;font-size:1.4rem;display:flex;position:sticky;top:0}.top-bar-logo{color:var(--text-primary);cursor:pointer;font-size:.95rem;font-weight:700;font-family:var(--font-title);align-items:center;gap:.5rem;font-size:1.4rem;display:flex}.top-bar-logo svg{color:var(--accent)}.top-bar-actions{align-items:center;gap:1rem;display:flex}.autosave-badge{color:#e2feea;letter-spacing:.02em;font-size:.75rem;font-family:var(--font)}.readonly-badge{color:var(--text-muted);background:var(--bg-elevated);border:1px solid var(--border);border-radius:500px;align-items:center;gap:.35rem;padding:.3rem .75rem;font-size:.75rem;display:flex}.share-banner{background:var(--accent-dim);border-bottom:1px solid #1db95433;align-items:center;gap:.75rem;padding:.6rem 1.5rem;font-size:.8rem;display:flex;overflow:hidden}.share-banner-label{color:var(--accent);white-space:nowrap;flex-shrink:0;font-weight:600}.share-banner-url{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.share-banner-copy{background:var(--accent);color:#000;cursor:pointer;border:none;border-radius:500px;flex-shrink:0;padding:.25rem .75rem;font-size:.75rem;font-weight:700;transition:background .15s}.share-banner-copy:hover{background:var(--accent-hover)}.app-layout{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:2rem 1.5rem 4rem}.playlist-header{align-items:flex-end;gap:1.5rem;margin-bottom:.5rem;padding:2rem 0 1.5rem;display:flex}.playlist-cover{border-radius:var(--radius-md);object-fit:cover;width:140px;height:140px;box-shadow:var(--shadow);flex-shrink:0}.playlist-cover--placeholder{background:var(--bg-elevated);color:var(--text-muted);justify-content:center;align-items:center;display:flex}.playlist-header-meta{flex-direction:column;gap:.25rem;display:flex}.playlist-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-size:.7rem;font-weight:700}.playlist-title{color:var(--accent);font-size:2rem;font-weight:800;line-height:1.15}.playlist-owner{color:var(--text-secondary);font-size:.85rem}.playlist-count{color:var(--text-muted);margin-top:.15rem;font-size:.8rem}.track-list-header{border-bottom:1px solid var(--border);align-items:center;margin-bottom:.25rem;padding:.5rem 1rem;display:flex}.col-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:.7rem;font-weight:700}.col-label--track{flex:1}.col-label--note{width:42%}.track-list{flex-direction:column;gap:2px;display:flex}.track-row{border-radius:var(--radius-sm);align-items:center;gap:1rem;padding:.6rem 1rem;transition:background .12s;display:flex}.track-row:hover{background:var(--bg-elevated)}.track-info{flex:1;align-items:center;gap:.75rem;min-width:0;display:flex}.track-index{color:var(--text-muted);text-align:right;flex-shrink:0;width:1.5rem;font-size:.8rem}.track-art{object-fit:cover;border-radius:4px;flex-shrink:0;width:40px;height:40px}.track-art--placeholder{background:var(--bg-highlight);color:var(--text-muted);justify-content:center;align-items:center;font-size:1rem;display:flex}.track-meta{flex-direction:column;flex:1;min-width:0;display:flex}.track-name{white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:500;overflow:hidden}.track-artist{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.track-duration{color:var(--text-muted);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:.78rem}.note-field{flex-shrink:0;width:42%}.note-textarea{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font);resize:vertical;min-height:56px;padding:.5rem .7rem;font-size:.82rem;line-height:1.5;transition:border-color .15s,background .15s}.note-textarea:focus{background:var(--bg-highlight);border-color:#1db95480;outline:none}.note-textarea::placeholder{color:var(--text-muted)}.note-display{color:var(--text-primary);white-space:pre-wrap;word-break:break-word;padding:.4rem 0;font-size:.82rem;line-height:1.6}.note-display--empty{color:var(--text-muted);font-style:italic}.home-page{background:radial-gradient(ellipse 80% 50% at 50% -10%, #1db9541f 0%, transparent 70%), var(--bg-base);justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;display:flex}.home-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:460px;box-shadow:var(--shadow);padding:2.5rem 2rem}.home-logo{color:var(--text-primary);font-size:1rem;font-weight:800;font-family:var(--font-title);align-items:center;gap:.6rem;margin-bottom:1.75rem;font-size:1.6rem;display:flex}.home-logo svg{color:var(--accent)}.home-title{margin-bottom:.5rem;font-size:1.6rem;font-weight:800;line-height:1.2}.home-subtitle{color:var(--text-secondary);margin-bottom:1rem;font-size:.9rem;line-height:1.6}.home-form{flex-direction:column;gap:.6rem;margin-bottom:1.25rem;display:flex}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.78rem;font-weight:600}.form-input{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font);width:100%;padding:.75rem 1rem;font-size:.9rem;transition:border-color .15s}.form-input:focus{border-color:#1db95480;outline:none}.form-input--error{border-color:#f55}.form-input::placeholder{color:var(--text-muted)}.form-input:disabled{opacity:.5;cursor:not-allowed}.form-error{color:#f55;font-size:.78rem}.home-hint{color:var(--text-muted);text-align:center;font-size:.75rem;line-height:1.6}.home-hint strong{color:var(--text-secondary)}@media (width<=640px){.playlist-header{flex-direction:column;align-items:flex-start;padding:1rem 0}.playlist-cover{width:100px;height:100px}.playlist-title{font-size:1.4rem}.track-list-header{display:none}.track-row{flex-wrap:wrap;padding:.75rem .5rem}.track-info{flex-basis:100%}.note-field{width:100%;padding-left:calc(2.25rem + 40px)}.share-banner-url{display:none}.controls-bar{flex-direction:column;align-items:stretch;gap:.5rem}}.controls-bar{align-items:center;gap:1rem;margin-bottom:.75rem;display:flex}.search-wrap{flex:1;align-items:center;max-width:360px;display:flex;position:relative}.search-icon{color:var(--text-muted);pointer-events:none;flex-shrink:0;position:absolute;left:.75rem}.search-input{background:var(--bg-elevated);border:1px solid var(--border);width:100%;color:var(--text-primary);font-family:var(--font);border-radius:500px;padding:.45rem .75rem .45rem 2.2rem;font-size:.82rem;transition:border-color .15s,background .15s}.search-input:focus{background:var(--bg-highlight);border-color:#1db95466;outline:none}.search-input::placeholder{color:var(--text-muted)}.search-clear{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:3px;padding:.2rem .3rem;font-size:.75rem;line-height:1;position:absolute;right:.6rem}.search-clear:hover{color:var(--text-primary)}.progress-pill{color:var(--text-muted);background:var(--bg-elevated);border:1px solid var(--border);white-space:nowrap;border-radius:500px;padding:.3rem .8rem;font-size:.75rem;font-weight:600;transition:color .2s,border-color .2s}.progress-pill--complete{color:var(--accent);background:var(--accent-dim);border-color:#1db95459}.no-results{text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:.75rem;padding:2.5rem 1rem;font-size:.9rem;display:flex}.no-results em{color:var(--text-secondary);font-style:normal;font-weight:500}.no-results-clear{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:500px;padding:.3rem .8rem;font-size:.78rem;transition:border-color .15s,color .15s}.no-results-clear:hover{border-color:var(--border-hover);color:var(--text-primary)}.note-field-inner{width:100%;position:relative}.char-count{color:var(--text-muted);pointer-events:none;font-variant-numeric:tabular-nums;font-size:.68rem;position:absolute;bottom:.35rem;right:.5rem}.char-count--warn{color:#e8a045}.char-count--limit{color:#f55}.note-textarea--limit{border-color:#ff555580!important}.btn-icon{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;border-radius:500px;align-items:center;gap:.4rem;padding:.45rem 1rem;font-size:.8rem;font-weight:600;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.btn-icon:hover{background:var(--bg-highlight);border-color:var(--border-hover);color:var(--text-primary)}.notfound-code{color:var(--bg-elevated);letter-spacing:-.05em;font-size:6rem;font-weight:900;line-height:1}.notfound-btn{width:auto;padding:.7rem 2rem}.share-strip{color:var(--text-secondary);justify-content:center;gap:.5rem;padding:1rem;font-size:.85rem;font-weight:400;display:flex}.btn-spotify{background:var(--accent);color:var(--bg-surface);cursor:pointer;border:none;border-radius:500px;justify-content:center;align-items:center;gap:.6rem;width:100%;padding:.75rem 1.5rem;font-size:.9rem;font-weight:600;display:inline-flex}.connected-badge{color:var(--text-secondary);align-items:center;gap:.6rem;padding:.45rem 1rem;font-size:.8rem;font-weight:400;display:inline-flex}.disconnect-btn{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border);border-radius:500px;padding:.45rem 1rem;font-size:.8rem;font-weight:400}.preview-player{appearance:none;cursor:pointer;background-color:var(--bg-surface);color:var(--accent);border:2px solid #0000;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;padding:0;display:flex}.preview-player--playing{background-color:var(--accent);color:var(--bg-surface);box-shadow:0 0 15px var(--accent)}
