@import "https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--bg-primary:#fff;--bg-secondary:#f3f6fc;--bg-tertiary:#e9eef6;--text-primary:#1f1f1f;--text-secondary:#444746;--text-tertiary:#727775;--accent-primary:#0b57d0;--accent-secondary:#0842a0;--accent-light:#d3e3fd;--on-accent-light:#041e49;--chord-color:#0b57d0;--chord-bg:#f3f6fc;--border-color:#c7c7c7;--font-body:"Outfit", -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Roboto Mono", monospace;--max-width:1200px;--radius-sm:8px;--radius-md:16px;--radius-lg:24px;--radius-pill:9999px;--shadow-sm:0 1px 2px 0 #0000001a;--shadow-md:0 4px 8px 3px #00000026;--shadow-lg:0 8px 16px 3px #00000026;--transition-fast:.2s cubic-bezier(.2, 0, 0, 1)}[data-theme=dark]{--bg-primary:#121212;--bg-secondary:#1e1f22;--bg-tertiary:#282a2d;--text-primary:#e3e3e3;--text-secondary:#c4c7c5;--text-tertiary:#8e918f;--accent-primary:#a8c7fa;--accent-secondary:#7cb0f9;--accent-light:#041e49;--on-accent-light:#d3e3fd;--chord-color:#a8c7fa;--chord-bg:#1e1f22;--border-color:#444746}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;line-height:1.5}h1,h2,h3,h4,h5,h6{color:var(--text-primary);letter-spacing:-.01em;font-weight:500}a{color:var(--accent-primary);transition:color var(--transition-fast);text-decoration:none}button{cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;font-family:inherit}#root{flex-direction:column;min-height:100vh;display:flex}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}@media (width<=640px){.container{padding:0 1rem}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.4s cubic-bezier(.2,0,0,1) forwards fadeIn}*{-webkit-tap-highlight-color:transparent}.layout{flex-direction:column;min-height:100vh;display:flex}.header{background:var(--bg-primary);z-index:50;position:sticky;top:0;box-shadow:0 1px 2px #0000000d}.header-content{justify-content:space-between;align-items:center;height:84px;display:flex}.brand{color:var(--text-secondary);align-items:center;gap:.75rem;font-size:2rem;font-weight:700;display:flex}.brand-image{object-fit:contain;background-color:var(--bg-primary);border-radius:6px;width:32px;height:32px}.brand-text-container{flex-direction:column;display:flex}.brand-text{line-height:1.1;font-size:2.25rem!important}.brand-subtitle{color:var(--text-tertiary);font-weight:400;line-height:1.2;font-size:1rem!important}.brand-icon{color:var(--accent-primary)}.nav-links{gap:.5rem;display:flex}.nav-link{color:var(--text-secondary);border-radius:var(--radius-pill);-webkit-tap-highlight-color:transparent;outline:none;justify-content:center;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.95rem;font-weight:500;text-decoration:none;display:flex}.nav-link:hover{background:var(--bg-secondary);color:var(--text-primary)}.nav-link:focus,.nav-link:active{outline:none}.nav-link.active{background:var(--accent-light);color:var(--accent-secondary);font-weight:600}.main-content{flex:1;padding:2rem 0}.footer{text-align:center;color:var(--text-tertiary);margin-top:auto;padding:2rem 0;font-size:.875rem}@media (width<=640px){.header-content{height:60px}.brand{font-size:1.5rem}.brand-text{font-size:1.5rem!important}.brand-subtitle{font-size:.85rem!important}.main-content{padding:1.5rem 0 6rem}.nav-links{background:var(--bg-primary);padding:.4rem .2rem calc(.4rem + env(safe-area-inset-bottom,0px)) .2rem;z-index:100;border-top:none;justify-content:space-between;gap:.1rem;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 10px #0000000d}.nav-link{border-radius:var(--radius-lg);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.25rem;min-width:0;padding:.4rem .1rem;font-size:.7rem;display:flex}.nav-link:hover{background:0 0}.nav-link.active{background:var(--accent-light);color:var(--accent-secondary);font-weight:600}}@media print{body{color:#000;background:#fff}.header,.footer,.nav-links,.controls-bar,.hide-on-print{display:none!important}.layout{min-height:auto;display:block}.main-content{margin:0;padding:0}.container{max-width:100%;margin:0;padding:0}*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}}.song-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-fast);padding:1rem 1.25rem;text-decoration:none;display:block}.song-card:hover{background:var(--bg-secondary);border-color:#0000}.song-card-title{color:var(--text-primary);margin:0 0 .25rem;font-size:1.125rem;font-weight:500}.song-card-artist{color:var(--text-tertiary);margin:0;font-size:.875rem}@media (width<=640px){.song-card{padding:.75rem 1rem}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.skeleton{background:var(--bg-tertiary);background-image:linear-gradient(90deg, var(--bg-tertiary) 0px, var(--border-color) 20%, var(--bg-tertiary) 40%, var(--bg-tertiary) 100%);border-radius:var(--radius-sm);opacity:.6;background-size:1000px 100%;animation:2.5s linear infinite forwards shimmer}[data-theme=light] .skeleton{background:#f0f0f0 linear-gradient(90deg,#f0f0f0 0,#e0e0e0 20%,#f0f0f0 40% 100%)}.skeleton-card{pointer-events:none;flex-direction:column;gap:.75rem;display:flex}.skeleton-title{border-radius:4px;width:70%;height:1.25rem}.skeleton-text{border-radius:4px;width:40%;height:.875rem}.skeleton-pill{border-radius:var(--radius-pill);width:80px;height:2rem}.page-header{margin-bottom:1.5rem}.page-header h1{margin-bottom:.25rem;font-size:1.8rem}.subtitle{color:var(--text-secondary);font-size:.95rem}.search-bar{margin-bottom:1.5rem;position:relative}.search-input{width:100%;color:var(--text-primary);background:var(--bg-secondary);border-radius:var(--radius-pill);transition:all var(--transition-fast);border:1px solid #0000;padding:.85rem 1.25rem;font-size:1rem}.search-input:focus{background:var(--bg-primary);border-color:var(--accent-primary);box-shadow:0 0 0 1px var(--accent-primary);outline:none}.form-input{width:100%;color:var(--text-primary);background:var(--bg-secondary);border-radius:var(--radius-sm);transition:all var(--transition-fast);border:1px solid #0000;padding:1rem 1.25rem;font-size:1rem}.form-input:focus{background:var(--bg-primary);border-color:var(--accent-primary);box-shadow:0 0 0 1px var(--accent-primary);outline:none}.filters{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:2rem;padding:1.5rem}.filter-group{margin-bottom:1.5rem}.filter-group label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.85rem;font-weight:500;display:block}.filter-select{width:100%;color:var(--text-primary);background:var(--bg-secondary);border-radius:var(--radius-sm);appearance:none;cursor:pointer;transition:all var(--transition-fast);border:1px solid #0000;padding:1rem 1.25rem;font-size:1rem}.filter-select:focus{border-color:var(--accent-primary);outline:none}.pill-group{flex-wrap:wrap;gap:.5rem;display:flex}.pill{border-radius:var(--radius-sm);color:var(--text-secondary);background:var(--bg-primary);border:1px solid var(--border-color);padding:.5rem 1rem;font-size:.875rem;font-weight:500}.pill:hover{background:var(--bg-secondary);color:var(--text-primary)}.pill.active{background:var(--accent-light);color:var(--on-accent-light);border-color:#0000}.song-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem;padding-bottom:6rem;display:grid}@media (width<=640px){.song-grid{grid-template-columns:1fr;gap:.75rem}}.empty-state{text-align:center;background:var(--bg-secondary);border-radius:var(--radius-lg);padding:4rem 1rem}.back-button{color:var(--text-secondary);align-items:center;gap:.5rem;margin-bottom:2rem;padding:.5rem 0;font-size:.875rem;font-weight:500;display:inline-flex}.back-button:hover{color:var(--text-primary)}.song-header{margin-bottom:2rem}.song-header h1{margin-bottom:.25rem;font-size:2.25rem}.form-grid{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}@media (width<=640px){.form-grid{grid-template-columns:1fr}}.controls-bar{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);flex-wrap:wrap;gap:2rem;margin-top:1.5rem;margin-bottom:2rem;padding:1rem 1.5rem;display:none}.controls-bar.open{display:flex}.control-group{align-items:center;gap:1rem;display:flex}.control-label{color:var(--text-secondary);font-size:.85rem;font-weight:500}@media (width<=640px){.controls-bar{flex-direction:column;gap:1.5rem;padding:1rem}.control-group{flex-direction:column;align-items:flex-start;gap:.75rem}.control-group .pill-group{justify-content:flex-start;width:100%}}.chips-container{-webkit-overflow-scrolling:touch;gap:.5rem;margin-bottom:1.5rem;padding-bottom:.5rem;display:flex;overflow-x:auto}.admin-tabs-wrapper{border-bottom:1px solid var(--border-color);margin:0 -1rem 2rem}.admin-tabs{white-space:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:1.5rem;padding:0 1rem;display:flex;overflow-x:auto}.admin-tabs::-webkit-scrollbar{display:none}.tab-btn{color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border-bottom:2px solid #0000;margin-bottom:-1px;padding:.75rem 0;font-size:1.1rem;font-weight:500}.tab-btn.active{color:var(--text-primary);border-bottom-color:var(--accent-primary);font-weight:600}.tab-btn:hover:not(.active){color:var(--text-secondary)}.chips-container::-webkit-scrollbar{display:none}.chip{background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-pill);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);padding:.5rem 1.25rem;font-size:.95rem;font-weight:500}.chip.active{background:var(--accent-primary);color:#fff;border-color:#0000}.song-viewer{background:var(--bg-primary);border-radius:var(--radius-md);font-family:var(--font-mono);white-space:pre;max-width:800px;margin:0 auto;padding:1rem 0;font-size:1rem;line-height:1.6;overflow-x:auto}.chord-line{color:var(--chord-color);margin-top:.5rem;padding:0;font-weight:400;display:block}.chord-token{color:var(--chord-color);font-weight:400}.lyric-line{color:var(--text-primary);margin-bottom:8px}.empty-line{height:1em}@media (width<=640px){.song-viewer{font-size:.95rem}}.print-only-info{display:none}@media print{.song-viewer{font-size:11pt;line-height:1.4;background:0 0!important;max-width:100%!important;margin:0!important;padding:0!important}.print-only-info{color:#444;font-size:11pt;font-family:var(--font-body);margin-bottom:1rem;display:block!important}.lyric-line{color:#000!important}.chord-line{page-break-after:avoid;break-after:avoid;font-weight:700;color:#444!important}.lyric-line{page-break-inside:avoid;break-inside:avoid}}
