:root{font-family:Segoe UI,system-ui,sans-serif;line-height:1.5;font-weight:400;color:#e8ecf4;background-color:#0b0d12;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-height:100vh}#app{min-height:100vh}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.page{max-width:42rem;margin:0 auto;padding:2.5rem 1.25rem 4rem}.app-chrome{position:sticky;top:0;z-index:100;background:linear-gradient(180deg,#0b0d12,#0b0d12 88%,#0b0d12eb);border-bottom:1px solid #1a1f2e;box-shadow:0 6px 16px #00000059}.app-nav{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;align-items:center;padding:.75rem 1.25rem 0;max-width:42rem;margin:0 auto}.projection-open-btn--nav{padding:.45rem 1rem;font-size:.88rem;font-weight:600;white-space:nowrap;min-height:40px;box-shadow:0 2px 10px #6366f133}.app-nav .app-nav-projection.projection-open-btn{position:relative;z-index:1;flex:1 1 12rem;max-width:100%;min-width:min(100%,11.5rem);min-height:44px;padding:.5rem 1.15rem;font-size:.92rem;font-weight:700;letter-spacing:.02em;border-radius:10px;border:2px solid #c4b5fd!important;background:linear-gradient(180deg,#818cf88c,#4f46e5a6)!important;color:#fafafa!important;box-shadow:0 2px #00000059,0 6px 18px #6366f18c!important}.app-nav .app-nav-projection.projection-open-btn:hover{filter:brightness(1.08);border-color:#e9d5ff!important}@media (min-width: 520px){.projection-open-btn--nav{margin-left:.35rem;padding-left:1.15rem;padding-right:1.15rem}}.app-nav-btn{padding:.45rem 1.1rem;border-radius:999px;border:1px solid #2e3548;background:#12151f;color:#9aa4bc;font-size:.9rem;font-weight:500;cursor:pointer}.app-nav-btn:hover{border-color:#4b5568;color:#e8ecf4}.app-nav-btn--active{border-color:#6366f1;background:#6366f126;color:#e8ecf4}.app-projection-bar{max-width:42rem;margin:0 auto;padding:.55rem 1.25rem .85rem}@media (min-width: 560px){.app-projection-bar{padding-bottom:1rem}}.app-projection-hint{margin:0;font-size:.78rem;color:#6b7390;line-height:1.45;text-align:center}@media (min-width: 560px){.app-projection-hint{text-align:left;max-width:none}}.hero{margin-bottom:2rem}.eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:.75rem;color:#7b8ab8;margin:0 0 .5rem}h1{font-size:2.25rem;font-weight:700;margin:0 0 .75rem;letter-spacing:-.03em;background:linear-gradient(120deg,#a78bfa,#38bdf8);-webkit-background-clip:text;background-clip:text;color:transparent}.lede{color:#9aa4bc;margin:0;font-size:1rem}.option-row{display:flex;align-items:flex-start;gap:.65rem;margin:0 0 1.25rem;padding:.75rem 1rem;border-radius:10px;border:1px solid #2e3548;background:#12151fa6;font-size:.95rem;color:#c5cce0;line-height:1.4}.option-row input[type=checkbox]{margin-top:.2rem;flex-shrink:0;accent-color:#6366f1;cursor:pointer}.option-row label{cursor:pointer}.option-row input:disabled+label{opacity:.6;cursor:not-allowed}.dropzone{border:1px dashed #2e3548;border-radius:12px;padding:1.75rem 1.25rem;text-align:center;background:linear-gradient(145deg,#12151f,#0e1018);transition:border-color .2s,box-shadow .2s}.dropzone--active:hover{border-color:#5b6a9e;box-shadow:0 0 0 1px #5b6a9e59}.file-input{position:absolute;width:0;height:0;opacity:0}.file-label{display:inline-block;padding:.65rem 1.4rem;border-radius:999px;background:linear-gradient(135deg,#6366f1,#2563eb);color:#fff;font-weight:600;cursor:pointer;font-size:.95rem}.file-label:hover{filter:brightness(1.08)}.hint{margin:1rem 0 0;font-size:.85rem;color:#6b7390}.meta{font-size:.9rem;color:#8b93a8;margin:1rem 0}.meta span{color:#c5cad9}.status{display:flex;align-items:flex-start;gap:1rem;margin:1.5rem 0;padding:1rem 1.25rem;border-radius:10px;background:#131722;border:1px solid #232938}.status-text{margin:0 0 .5rem;font-size:.9rem;color:#b4bcd4}progress{width:100%;height:6px;accent-color:#6366f1}.spinner{width:22px;height:22px;border:2px solid #2e3548;border-top-color:#818cf8;border-radius:50%;flex-shrink:0;animation:spin .85s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.banner{padding:.85rem 1rem;border-radius:8px;font-size:.9rem;margin:1rem 0}.banner--warn{background:#eab3081f;border:1px solid rgba(234,179,8,.35);color:#facc15}.banner--err{background:#ef44441f;border:1px solid rgba(239,68,68,.35);color:#fca5a5}.player-section{margin:1.5rem 0}.player{width:100%;border-radius:8px}.sync-tuning{margin:1.25rem 0 0;padding:1rem 1.1rem;border-radius:12px;border:1px solid #2e3548;background:#12151f80}.sync-tuning-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.5rem}.sync-tuning-label{font-size:.9rem;color:#b4bcd4;font-weight:500}.sync-tuning-value{font-variant-numeric:tabular-nums;font-size:.9rem;color:#a78bfa;min-width:5rem;text-align:right}.sync-tuning-range{width:100%;height:6px;accent-color:#818cf8;margin:0 0 .75rem}.sync-tuning-hint{margin:0 0 .75rem;font-size:.8rem;color:#6b7390;line-height:1.45}.sync-reset{padding:.35rem .85rem;font-size:.85rem;border-radius:8px;border:1px solid #3e4558;background:#161a24;color:#c5cce0;cursor:pointer}.sync-reset:hover{border-color:#5b6a9e;color:#e8ecf4}.lyrics{margin-top:2rem}.lyrics h2{font-size:1rem;font-weight:600;color:#8b93a8;margin:0;text-transform:uppercase;letter-spacing:.06em}.lyrics-header-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem 1rem;margin-bottom:.85rem}.projection-open-btn--inline{font-size:.78rem;padding:.32rem .85rem}.projection-open-btn{flex-shrink:0;padding:.38rem 1rem;border-radius:8px;border:1px solid #6366f1;background:#6366f11f;color:#c4b5fd;font-size:.82rem;font-weight:600;cursor:pointer}.projection-open-btn:hover{background:#6366f138;color:#ede9fe;border-color:#818cf8}.projection-open-btn:focus-visible{outline:2px solid #6366f1;outline-offset:2px}.spotify-projection-callout{display:flex;flex-wrap:wrap;align-items:center;gap:.85rem 1.25rem;margin:0 0 1.25rem;padding:1rem 1.1rem;border-radius:12px;border:1px solid rgba(99,102,241,.45);background:#6366f114}.spotify-projection-callout-text{margin:0;flex:1;min-width:12rem;font-size:.88rem;color:#9aa4bc;line-height:1.45}.projection-open-btn--spotify{flex-shrink:0;padding:.55rem 1.15rem;font-size:.9rem;min-height:44px}.lyrics-meta{margin:0 0 1rem;font-size:.8rem;color:#6b7390}.lyrics-empty{margin:0;padding:1rem 1.1rem;border-radius:12px;border:1px dashed #2e3548;font-size:.9rem;color:#7b8499;line-height:1.5}.projection-page-hint{margin:1rem 0 0;padding:.65rem .85rem;border-radius:8px;border:1px dashed #2e4058;font-size:.85rem;color:#8b93a8;line-height:1.45}.lyrics-source-fieldset{flex-direction:column;align-items:stretch;gap:.5rem;margin:0 0 1rem;padding:.75rem 1rem;border-radius:10px;border:1px solid #2e3548;background:#12151fa6}.lyrics-source-fieldset legend{padding:0 .35rem;font-size:.85rem;color:#8b93a8;font-weight:600}.radio-label{display:flex;align-items:center;gap:.45rem;cursor:pointer;font-size:.95rem;color:#c5cce0}.radio-label input{accent-color:#6366f1;cursor:pointer}.lyrics-query-row{flex-direction:column;align-items:stretch;gap:.4rem}.lyrics-query-label{font-size:.85rem;color:#8b93a8}.lyrics-query-input{width:100%;padding:.55rem .75rem;border-radius:8px;border:1px solid #2e3548;background:#0e1118;color:#e8ecf4;font-size:.95rem}.lyrics-query-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 2px #6366f140}.lyrics-query-input:disabled{opacity:.5}.lyrics-list{list-style:none;margin:0;padding:0;border-radius:12px;border:1px solid #232938;background:#0e1118;max-height:min(50vh,22rem);overflow-y:auto}.lyrics-line{padding:.65rem 1rem;font-size:1.05rem;color:#9aa3bb;border-bottom:1px solid #1a1f2e;transition:background .15s,color .15s}.lyrics-line:last-child{border-bottom:none}.lyrics-line--active{background:linear-gradient(90deg,rgba(99,102,241,.15) 0%,transparent 100%);color:#f1f5f9;font-weight:500}.footer{margin-top:3rem;padding-top:1.5rem;border-top:1px solid #1e2433;font-size:.8rem;color:#5c6378}.footer p{margin:0}.spotify-page .spotify-connect-panel{margin-bottom:1.5rem}.spotify-login-btn{border:none;background:linear-gradient(135deg,#1db954,#169c46)}.spotify-user-row{justify-content:space-between;align-items:center;flex-wrap:wrap}.spotify-no-premium{color:#facc15}.spotify-search-row{display:flex;gap:.65rem;flex-wrap:wrap;margin-bottom:1rem}.spotify-search-row .lyrics-query-input{flex:1;min-width:12rem}.spotify-search-btn{border:none}.spotify-results{list-style:none;margin:0;padding:0;border-radius:10px;border:1px solid #232938;max-height:14rem;overflow-y:auto}.spotify-result-item{display:flex;align-items:stretch}.spotify-result-item:last-child .spotify-track-btn{border-bottom:none}.spotify-result-body{flex:1;min-width:0}.spotify-open-btn{flex-shrink:0;margin:0;padding:0 .95rem;align-self:stretch;border:none;border-left:1px solid #1a1f2e;background:#1db9541f;color:#4ade80;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;cursor:pointer}.spotify-open-btn:hover{background:#1db95438;color:#bbf7d0}.spotify-open-btn:focus-visible{outline:2px solid #1db954;outline-offset:-2px}.spotify-track-btn{display:flex;flex-direction:column;align-items:flex-start;width:100%;padding:.65rem 1rem;border:none;border-bottom:1px solid #1a1f2e;background:transparent;color:#c5cce0;text-align:left;cursor:pointer}.spotify-track-btn:hover:not(:disabled){background:#6366f114}.spotify-track-btn:disabled{cursor:not-allowed;opacity:.55}.spotify-track-title{font-weight:600;color:#e8ecf4}.spotify-track-meta{font-size:.8rem;color:#6b7390;margin-top:.2rem}.spotify-now{margin:1.5rem 0;padding:1rem 1.15rem;border-radius:12px;border:1px solid #2e3548;background:#12151f80}.spotify-now-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;color:#6b7390;margin:0 0 .35rem}.spotify-now-title{margin:0;font-size:1.15rem;font-weight:600;color:#e8ecf4}.spotify-now-artists{margin:.25rem 0 .75rem;font-size:.9rem;color:#9aa4bc}.spotify-transport{margin-bottom:.5rem}.spotify-legal{margin-bottom:0;font-size:.75rem}.inline-code{font-size:.75rem;word-break:break-all}
