@import "https://fonts.googleapis.com/css2?family=Recursive:wght@300;400;500;600;700;800&display=swap";:root{color:#111827;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;--blue:#316dca;--blue-dark:#2d7de8;--gray-50:#f8f9fa;--gray-100:#eef2f7;--gray-500:#6b7280;--shadow-sm:0 1px 3px #0f172a1f;--shadow-md:0 8px 28px #0f172a24;background:#fff;font-family:Recursive,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{overflow-x:hidden}button,input,textarea{font:inherit}a{color:inherit}.app{min-height:100vh;box-shadow:var(--shadow-sm);background:#fff;flex-direction:column;display:flex}.topbar{background:var(--gray-50);padding:20px}.topbar-inner{justify-content:space-between;align-items:center;gap:18px;width:min(992px,100%);margin:0 auto;display:flex}.brand-cluster{align-items:center;gap:10px;min-width:0;display:flex}.brand{white-space:nowrap;align-items:center;gap:7px;min-width:0;font-size:18px;font-weight:800;text-decoration:none;display:inline-flex}.brand-mark{background:linear-gradient(135deg, var(--blue-dark), var(--blue));border-radius:10%;flex:none;width:20px;height:20px}.brand-name{text-overflow:ellipsis;overflow:hidden}.icon-chip{color:#fff;background:linear-gradient(90deg, var(--blue-dark), var(--blue));cursor:pointer;border:0;border-radius:999px;flex:none;place-items:center;width:28px;height:28px;display:inline-grid}.github-button{color:#fff;background:var(--blue);border-radius:999px;justify-content:center;align-items:center;gap:8px;min-height:40px;padding:9px 18px;font-size:14px;font-weight:600;text-decoration:none;display:inline-flex}.notice{background:var(--blue);color:#f8fafc;padding:20px;font-size:11px;font-weight:400}.screen{flex-direction:column;flex:1;justify-content:center;gap:40px;width:100%;padding:34px 0 42px;display:flex}.song-rail{width:100%}.rail-scroll{scrollbar-width:none;align-items:flex-start;gap:14px;width:100%;padding:4px 24px 18px;display:flex;overflow:auto hidden}.rail-scroll::-webkit-scrollbar{display:none}.song-card,.song-skeleton,.detail-skeleton{width:min(400px,100vw - 32px);min-width:min(400px,100vw - 32px);height:285px;min-height:285px;max-height:285px;box-shadow:var(--shadow-sm);border-radius:6px;margin:12px;padding:20px}.song-card{flex-direction:column;justify-content:flex-start;gap:8px;min-height:0;display:flex;overflow:hidden}.song-card.compact{flex:0 0 min(400px,100vw - 48px);justify-content:flex-start;width:min(400px,100vw - 48px);min-width:min(400px,100vw - 48px)}.song-card:not(.compact){flex:0 0 min(400px,100vw - 32px)}.song-skeleton,.detail-skeleton{background:linear-gradient(90deg,#f1f5f9,#e2e8f0,#f1f5f9) 0 0/220% 100%;animation:1.4s linear infinite shimmer}.song-actions{justify-content:center;align-items:center;gap:20px;min-height:30px;display:flex}.song-card.compact .song-actions{flex:none;min-height:30px}.song-icon{cursor:pointer;background:0 0;border:0;place-items:center;width:34px;height:30px;text-decoration:none;display:inline-grid}.song-card.compact .song-icon{width:34px;height:30px}.generation-panel{color:#111827;width:min(400px,100vw - 32px);margin:12px;padding:0}.song-rail .generation-panel{flex:0 0 min(400px,100vw - 48px)}.detail-card-wrap .generation-panel{margin-inline:auto}.download-wrap{position:relative}.download-menu{z-index:15;color:#111827;width:132px;box-shadow:var(--shadow-md);background:#fffffff5;border:1px solid #94a3b847;border-radius:5px;gap:4px;padding:8px;display:grid;position:absolute;top:38px;left:50%;transform:translate(-50%)}.download-menu span{color:#475569;padding:5px 8px;font-size:12px;font-weight:700}.download-menu a{border-radius:4px;padding:7px 8px;font-size:14px;text-decoration:none}.download-menu a:hover{background:#f1f5f9}.song-status{text-align:center;flex-direction:column;flex:auto;justify-content:center;min-height:0;font-size:15px;font-weight:600;display:flex}.song-card.compact .song-status{flex:auto;min-height:0}.generation-progress{text-align:left;gap:12px;width:100%;padding:6px 2px 2px}.progress-header{grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;display:grid}.progress-icon{opacity:.8;border:1px solid;border-radius:999px;place-items:center;width:32px;height:32px;display:inline-grid}.progress-icon .spinning{animation:1s linear infinite abcjs-spin}.progress-copy{gap:2px;min-width:0;display:grid}.progress-copy strong{text-overflow:ellipsis;white-space:nowrap;font-size:15px;overflow:hidden}.progress-copy span,.progress-meta{opacity:.72;font-size:11px;font-weight:500;line-height:1.35}.progress-percent{font-size:13px;font-weight:800}.progress-track{background:color-mix(in srgb, currentColor 18%, transparent);border-radius:999px;height:8px;overflow:hidden}.progress-track span{border-radius:inherit;background:currentColor;height:100%;transition:width .32s;display:block}.progress-steps{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;margin:0;padding:0;list-style:none;display:grid}.progress-steps li{opacity:.5;white-space:nowrap;align-items:center;gap:4px;min-width:0;font-size:10px;font-weight:800;line-height:1.2;display:flex}.progress-steps li.active,.progress-steps li.done{opacity:1}.progress-steps li span{border:1px solid;border-radius:999px;flex:0 0 12px;place-items:center;width:12px;height:12px;display:inline-grid}.progress-steps li.done span{border:0}.progress-meta{margin:0}.generation-progress.failed .progress-track span{background:#991b1b}.song-card.compact .generation-progress{gap:9px;padding-top:0}.song-card.compact .progress-copy span,.song-card.compact .progress-meta{display:none}.song-card.compact .progress-header{gap:8px}.song-card.compact .progress-icon{width:28px;height:28px}.song-card.compact .progress-copy strong{font-size:13px}.song-card.compact .progress-steps{gap:4px}.song-card.compact .progress-steps li{font-size:9px}.composer{flex-direction:column;align-items:center;gap:22px;width:min(992px,100%);margin:0 auto;padding:0 20px;display:flex}.instrument-select{z-index:5;min-width:250px;max-width:min(720px,92vw)}.prompt-shell{background:#fff;border:1px solid #e8edf4;border-radius:18px;grid-template-columns:46px 1fr 46px;align-items:center;width:min(720px,100vw - 40px);min-height:64px;transition:box-shadow .16s,border-color .16s;display:grid;box-shadow:0 1px 3px #0f172a0f}.prompt-shell:hover{border-color:#dde5ef;box-shadow:0 3px 10px #0f172a14}.prompt-shell:focus-within{border-color:#cbd7e6;box-shadow:0 4px 14px #316dca1a}.prompt-shell textarea{resize:none;color:#111827;background:0 0;border:0;outline:0;width:100%;height:42px;min-height:42px;max-height:42px;padding:9px 4px;font-size:17px;line-height:1.4;overflow:hidden}.prompt-shell textarea::placeholder{color:#98a1af}.prompt-icon,.palette-button{color:#98a1af;cursor:pointer;background:0 0;border:0;border-radius:999px;place-self:center;place-items:center;width:34px;height:34px;display:inline-grid}.palette-button{color:#fff;background:var(--blue)}.hint{text-align:center;color:#374151;max-width:400px;margin:-8px 0 0;padding:0 20px;font-size:11px;line-height:1.6}.generate-button{border:1px solid var(--gray-100);color:#1f2937;min-width:200px;min-height:52px;box-shadow:var(--shadow-sm);cursor:pointer;background:0 0;border-radius:8px;padding:12px 28px;font-size:18px;font-weight:700}.generate-button:not(:disabled):hover{box-shadow:var(--shadow-md)}.generate-button:disabled{cursor:not-allowed;opacity:.55}.loading-note,.error-note{margin:-10px 0 0;font-size:14px}.error-note{color:#b91c1c}.submit-progress{gap:8px;width:min(280px,100%);margin-top:-8px;display:grid}.submit-progress span{background:#e5eaf2;border-radius:999px;height:6px;position:relative;overflow:hidden}.submit-progress span:before{content:"";border-radius:inherit;background:var(--blue);width:45%;animation:1.15s ease-in-out infinite indeterminate-progress;position:absolute;inset:0}.submit-progress p{color:#64748b;text-align:center;margin:0;font-size:12px;font-weight:700}.detail-screen{gap:28px}.detail-card-wrap{justify-content:center;display:flex}.detail-compose{gap:18px;display:grid}.examples-link{color:#4b5563;justify-self:center;font-size:12px;text-decoration:none}.empty-state{color:#64748b;text-align:center;margin:12px 20px;font-size:14px}.color-screen{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:30px;min-height:calc(100vh - 178px);padding:42px 20px;display:flex}.color-generate{background:0 0}.footer{background:var(--gray-50);flex-direction:column;align-items:center;gap:8px;padding:12px 20px;display:flex}.footer a{text-decoration:underline}.footer p{text-align:center;color:#111827;margin:0;font-size:11px;font-weight:700}.modal-backdrop{z-index:100;background:#0f172a66;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.modal{color:#111827;width:min(500px,100%);max-height:min(86vh,720px);box-shadow:var(--shadow-md);background:#fff;border-radius:8px;flex-direction:column;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;gap:16px;padding:18px 20px;display:flex}.modal-header h2{margin:0;font-size:17px}.modal-header button{cursor:pointer;background:0 0;border:0;width:34px;height:34px}.modal-body{padding:20px;overflow:auto}.modal-body p{color:#374151;margin:0;line-height:1.6}.modal-copy{margin-bottom:14px}.settings-textarea{resize:vertical;border:1px solid #d1d5db;border-radius:6px;outline:none;width:100%;min-height:260px;padding:10px;line-height:1.45}.reset-button{color:#475569;cursor:pointer;background:0 0;border:0;margin:12px auto 0;display:block}.response-text{white-space:pre-wrap;color:#111827;margin:0;font-family:inherit;font-size:14px;line-height:1.5}.abc-player{flex-direction:column;flex:1 1 0;gap:12px;min-height:0;display:flex;overflow:hidden}.compact-player{flex-direction:column;flex:1 1 0;gap:6px;min-height:0;display:flex;overflow:hidden}.abcjs-scroll{overscroll-behavior-y:contain;scrollbar-width:thin;flex:1 1 0;width:100%;min-height:0;overflow:hidden auto}.compact-player .abcjs-scroll{flex:1 1 0;min-height:0;overflow:hidden auto}.abcjs-container{width:100%;overflow:visible}.abcjs-container svg{max-width:100%;display:block}.compact-player .abcjs-container svg{display:block}.abcjs-audio-shell{flex:none;min-height:34px;overflow:hidden}.inverse *{color:#111827!important;fill:#111827!important;stroke:#111827!important;border-color:#111827!important}.abcjs-container text,.abcjs-container tspan,.inverse .abcjs-container text,.inverse .abcjs-container tspan{stroke:none!important;stroke-width:0!important;font-family:Georgia,Times New Roman,serif!important;font-weight:400!important}.abcjs-inline-audio{box-sizing:border-box;background-color:#0000;border-radius:3px;align-items:center;height:26px;padding:0 5px;display:flex}.compact-player .abcjs-audio{flex:0 0 34px;min-width:0;overflow:hidden}.compact-player .abcjs-audio-shell{min-height:34px}.compact-player .abcjs-inline-audio{width:100%;min-width:0;height:34px;padding:0;overflow:hidden}.abcjs-inline-audio.abcjs-disabled{opacity:.5}.abcjs-inline-audio .abcjs-btn{box-sizing:border-box;width:28px;height:34px;margin-right:2px;padding:7px 4px;line-height:1;display:block;background:0 0!important;border:0!important}.compact-player .abcjs-inline-audio .abcjs-btn{width:26px;min-width:26px;height:30px;padding:5px 3px}.abcjs-btn g{fill:#f4f4f4;stroke:#f4f4f4}.abcjs-inline-audio .abcjs-btn:hover g{fill:#ccc;stroke:#ccc}.abcjs-inline-audio .abcjs-midi-start .abcjs-pause-svg,.abcjs-inline-audio .abcjs-midi-start .abcjs-loading-svg,.abcjs-inline-audio .abcjs-midi-start.abcjs-pushed .abcjs-play-svg,.abcjs-inline-audio .abcjs-midi-start.abcjs-loading .abcjs-play-svg{display:none}.abcjs-inline-audio .abcjs-midi-start.abcjs-pushed .abcjs-pause-svg,.abcjs-inline-audio .abcjs-midi-start.abcjs-loading .abcjs-loading-svg{display:block}.abcjs-inline-audio .abcjs-midi-progress-background{box-sizing:border-box;background-color:#424242;border:2px solid #ccc;border-radius:5px;flex:1;height:10px;margin:0 8px 0 15px;padding:0;position:relative}.compact-player .abcjs-inline-audio .abcjs-midi-progress-background{min-width:60px;margin:0 6px}.abcjs-inline-audio .abcjs-midi-progress-indicator{box-sizing:border-box;background-color:#f4f4f4;border-radius:6px;width:20px;height:14px;margin-left:-10px;display:inline-block;position:absolute;top:-4px;left:0}.abcjs-inline-audio .abcjs-midi-clock{box-sizing:border-box;color:#f4f4f4;margin-top:1px;margin-left:4px;margin-right:2px;font-family:sans-serif;font-size:16px;display:inline-block}.compact-player .abcjs-inline-audio .abcjs-midi-clock{white-space:nowrap;flex:none;margin:1px 0 0;font-size:12px}.abcjs-inline-audio .abcjs-tempo-wrapper{color:#f4f4f4;box-sizing:border-box;align-items:center;font-size:10px;display:flex}.compact-player .abcjs-inline-audio .abcjs-tempo-wrapper{display:none}.abcjs-inline-audio .abcjs-midi-tempo{box-sizing:border-box;border:none;border-radius:2px;width:42px;margin:0 2px 0 4px;padding-left:2px}.abcjs-inline-audio .abcjs-loading{outline:none;animation-name:abcjs-spin;animation-duration:1s;animation-timing-function:linear;animation-iteration-count:infinite}.abcjs-css-warning{display:none}@keyframes shimmer{0%{background-position:220% 0}to{background-position:-220% 0}}@keyframes abcjs-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes indeterminate-progress{0%{transform:translate(-110%)}55%{transform:translate(70%)}to{transform:translate(230%)}}@media (width<=640px){.topbar-inner{align-items:center;gap:12px}.topbar{padding:16px}.brand-cluster{flex:auto}.brand{font-size:16px}.github-button{width:44px;min-width:44px;padding:0}.github-button span{display:none}.screen{gap:28px;padding-top:22px}.prompt-shell{border-radius:22px;grid-template-columns:40px 1fr 44px;width:100%}.prompt-shell textarea{font-size:16px}.song-card,.song-skeleton{margin:8px}.rail-scroll{gap:8px;padding-inline:12px}.song-card.compact{flex-basis:min(360px,100vw - 40px);width:min(360px,100vw - 40px);min-width:min(360px,100vw - 40px)}}
