.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.modal-content{position:relative;background:#fff;padding:2rem;border-radius:12px;width:100%;max-width:400px;box-shadow:0 4px 20px #00000040;animation:modalFadeIn .2s ease-in-out;box-sizing:border-box}.modal-close{position:absolute;top:10px;right:10px;background:transparent;border:none;font-size:20px;cursor:pointer;padding:4px;line-height:1}.modal-title{color:#121212;margin:0 0 1.5rem;font-size:1.25rem}.modal-content input{width:100%;padding:.5rem;margin-bottom:1rem;border:1px solid #ccc;border-radius:6px;font-size:1rem;box-sizing:border-box}.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:1.5rem}.modal-footer button{flex:1}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media(max-width:500px){.modal-content{padding:1.5rem}.modal-footer{flex-direction:column;gap:.5rem}}.btn{padding:.6rem 1.5rem;border-radius:9999px;border:none;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn-primary{background-color:#1db954;color:#000}.btn-secondary{background-color:#eee;color:#333}.btn-danger{background-color:#e53935;color:#fff}.btn-ghost{background:transparent;color:inherit;padding:.4rem}.btn-icon{background:none;border:none;padding:.4rem;font-size:1.2rem;cursor:pointer;transition:transform .1s}@media(hover:hover){.btn-primary:hover{background-color:#25c75f}.btn-secondary:hover{background-color:#ddd}.btn-danger:hover{background-color:#c62828}.btn-ghost:hover{background-color:#ffffff1a}.btn-icon:hover{transform:scale(1.2)}}.btn-small{padding:.4rem 1rem;font-size:.85rem}.btn-medium{padding:.6rem 1.5rem;font-size:.95rem}.btn-large{padding:.75rem 2rem;font-size:1rem}.btn-full{width:100%}.btn-disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.input-wrapper{position:relative;display:flex;align-items:center;width:100%}.input-wrapper input{width:100%;padding:.5rem;border:1px solid #ccc;border-radius:6px;font-size:1rem;box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.input-wrapper input:focus{outline:none;border-color:#1db954;box-shadow:0 0 0 2px #1db95433}.input-wrapper input.has-clear{padding-right:2.5rem}.input-clear{position:absolute;right:8px;background:none;border:none;cursor:pointer;font-size:14px;opacity:.5;padding:4px;line-height:1}.input-clear:hover{opacity:1}.input-label{display:block;color:#222;font-weight:500;font-size:.95rem}.input-label .input-wrapper{margin-top:.25rem}.meter-chips{display:flex;flex-direction:column;gap:.5rem}.meter-label{color:#222;font-weight:500;font-size:.95rem}.chips-row{display:flex;gap:.5rem}.chip{padding:.5rem 1rem;border-radius:20px;border:1px solid #333;background:#222;color:#fff;cursor:pointer;transition:all .2s;font-size:.9rem;font-weight:500}.chip:hover{background:#1db954;border-color:#1db954}.chip.active{background:#1db954;color:#000;border-color:#1db954}.login-page{min-height:100vh;width:100%;display:flex;justify-content:center;align-items:center;background:linear-gradient(to bottom,#121212,#1db954 80%)}.login-card{background:#121212;border-radius:14px;padding:2.5rem 2rem;width:100%;max-width:360px;text-align:center;box-shadow:0 10px 30px #0009;animation:fadeIn .4s ease}.login-logo{font-size:3rem;margin-bottom:.5rem}.login-title{font-size:1.8rem;font-weight:700;margin:.3rem 0;color:#fff}.login-subtitle{font-size:.9rem;color:#b3b3b3;margin-bottom:2rem}.login-button{width:100%;padding:.75rem 1rem;display:flex;align-items:center;justify-content:center;gap:10px;background-color:#fff;color:#121212;font-weight:700;font-size:.95rem;border:none;border-radius:9999px;cursor:pointer;transition:background-color .2s,transform .1s}.login-button img{width:18px;height:18px}.login-button:hover{background-color:#25c75f;transform:translateY(-1px)}.login-button:active{transform:translateY(0)}.header{display:flex;justify-content:space-between;align-items:center;padding:.8rem 1.5rem;position:sticky;top:0;z-index:50}.header-left{display:flex;align-items:center;gap:.5rem}.header-icon{font-size:1.6rem}.header-title{font-size:1rem;font-weight:500}.header-right{position:relative}.avatar{width:38px;height:38px;border-radius:50%;cursor:pointer;object-fit:cover;border:1px solid #ccc}.profile-wrapper{cursor:pointer}.profile-menu{position:absolute;right:0;top:110%;background:#fff;border:1px solid #ccc;border-radius:6px;box-shadow:0 4px 10px #00000026;z-index:100;min-width:120px;display:flex;flex-direction:column}.profile-menu-item{padding:.5rem 1rem;background:none;border:none;text-align:left;cursor:pointer;width:100%;font-size:.95rem;color:#333}.profile-menu-item:hover{background-color:#f5f5f5}:root{--bottom-tabs-height: 65px}.bottom-tabs{position:fixed;bottom:0;left:0;right:0;height:var(--bottom-tabs-height);background:#181818;border-top:1px solid #333;display:flex;z-index:1000}.bottom-tabs a{flex:1;border:none;background:none;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:20px;color:#888;cursor:pointer;gap:4px;transition:color .2s;text-decoration:none}.bottom-tabs a span{font-size:11px}.bottom-tabs a.active{color:#1db954}.bottom-tabs a:hover{color:#fff}.bottom-tabs a.active:hover{color:#1db954}.songCard{display:flex;justify-content:space-between;align-items:center;padding:1rem;border:1px;border-radius:10px;cursor:pointer;background-color:#222}.songInfo h2{color:#1db954;margin:0 0 .3rem;font-size:1.1rem}.songInfo p{margin:0;color:#ccc;font-size:.9rem}.songActions{display:flex;gap:.5rem}.iconButton{background:none;border:none;font-size:1.2rem;cursor:pointer;transition:transform .1s}.iconButton:hover{transform:scale(1.2)}.editor-block{margin-bottom:1.25rem}.editor-subtitle{margin:0 0 .75rem;color:#222;font-size:1rem}.tempo-row{display:flex;gap:8px;margin-bottom:8px}.tempo-row input{flex:1;padding:.5rem;border:1px solid #ccc;border-radius:6px;font-size:.9rem}.tempo-row button{background:none;border:none;cursor:pointer;font-size:16px;padding:.5rem}.tempo-row button:hover{opacity:.7}.add-tempo-btn{margin-top:6px;background:#eee;border:none;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:.9rem}.add-tempo-btn:hover{background:#ddd}.editor-info{color:#666;font-size:.85rem;margin:1rem 0 0}.metronome-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;opacity:.7}.metronome-icon{font-size:4rem;margin-bottom:1rem}.metronome-placeholder h2{margin:0 0 .5rem;font-size:1.5rem}.metronome-placeholder p{margin:0;font-size:1rem;opacity:.7}.playlist-select-wrapper{position:relative;width:100%}.playlist-select{background:linear-gradient(to bottom,#2a2a2a,#222);color:#fff;padding:.85rem 1rem;border-radius:12px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:1rem;border:1px solid #3a3a3a;width:100%;box-sizing:border-box;transition:all .2s ease;font-weight:500}.playlist-select:hover{background:linear-gradient(to bottom,#333,#2a2a2a);border-color:#4a4a4a}.playlist-select.is-open{border-color:#1db954;box-shadow:0 0 0 2px #1db95433}.playlist-select .placeholder{color:#888}.playlist-select .selected-name{color:#fff;display:flex;align-items:center;gap:.5rem}.playlist-select .selected-name:before{content:"📋";font-size:.9rem}.playlist-select .caret{font-size:.75rem;color:#888;transition:transform .2s ease}.playlist-select.is-open .caret{transform:rotate(180deg);color:#1db954}.playlist-dropdown{position:absolute;top:calc(100% + 8px);left:0;width:100%;background:#2a2a2a;border-radius:12px;border:1px solid #3a3a3a;z-index:1000;box-shadow:0 8px 30px #0006;animation:dropdownFadeIn .2s ease;overflow:hidden;max-height:280px;overflow-y:auto}.playlist-dropdown::-webkit-scrollbar{width:6px}.playlist-dropdown::-webkit-scrollbar-track{background:#222}.playlist-dropdown::-webkit-scrollbar-thumb{background:#444;border-radius:3px}.playlist-dropdown::-webkit-scrollbar-thumb:hover{background:#555}.playlist-option{padding:.75rem 1rem;cursor:pointer;font-size:.95rem;color:#ccc;transition:all .15s ease;display:flex;align-items:center;gap:.6rem}.playlist-option:before{content:"🎵";font-size:.85rem;opacity:.7}.playlist-option:hover{background:#333;color:#fff}.playlist-option:active{background:#3a3a3a}.playlist-option.selected{background:#1db95426;color:#1db954}.playlist-option.selected:before{content:"✓"}.playlist-divider{height:1px;background:#3a3a3a;margin:6px 0}.playlist-option.add-new{font-weight:600;color:#1db954;padding-top:.85rem;padding-bottom:.85rem}.playlist-option.add-new:before{content:""}.playlist-option.add-new:hover{background:#1db9541a;color:#1db954}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.playlists-tab{display:flex;flex-direction:column;gap:1rem}.playlist-actions{display:flex;gap:.5rem}.playlists-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center;gap:1rem}.playlists-empty p{margin:0;opacity:.7}.playlists-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;gap:1rem}.playlists-loading p{color:#888;font-size:.95rem;margin:0}.playlists-loader{width:40px;height:40px;border:3px solid #333;border-top-color:#1db954;border-radius:50%;animation:playlistsSpin .8s linear infinite}@keyframes playlistsSpin{to{transform:rotate(360deg)}}.sortable-song{display:flex;align-items:stretch;gap:0}.sortable-song.is-dragging{z-index:1000}.drag-handle{display:flex;align-items:center;justify-content:center;padding:0 .5rem;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;color:#fff;background:#ffffff0d;border-radius:8px 0 0 8px}.drag-handle:active{cursor:grabbing}.drag-icon{font-size:1rem;letter-spacing:-2px}.sortable-song .songCard{flex:1;border-radius:0 8px 8px 0}@media(hover:hover){.drag-handle:hover{background:#ffffff1a;color:#1db954}}.playlist-view{display:flex;flex-direction:column;gap:1rem}.playlist-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.playlist-header h2{margin:0}.playlist-header-actions{display:flex;gap:.5rem;align-items:center}@media(max-width:500px){.playlist-header-actions{justify-content:space-between}}.share-btn{position:relative}@media(max-width:500px){.share-btn{order:1}}.playlist-songs{display:flex;flex-direction:column;gap:1rem}.playlist-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;margin:1rem 0;text-align:center;background:#f8f9fa;border-radius:12px}.playlist-empty-icon{font-size:2.5rem;margin-bottom:.75rem}.playlist-empty-title{font-size:1.1rem;font-weight:600;margin:0 0 .25rem;color:#1f2937}.playlist-empty-hint{font-size:.875rem;color:#9ca3af;margin:0;max-width:260px;line-height:1.4}.playlist-footer{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.playlist-footer h2{margin:0}.playlist-danger-zone{margin-top:.5rem}.playlist-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;gap:1rem}.playlist-loading p{color:#888;font-size:.95rem;margin:0}.playlist-loader{width:40px;height:40px;border:3px solid #333;border-top-color:#1db954;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.shared-playlist-view{position:fixed;inset:0;display:flex;flex-direction:column;background:linear-gradient(to bottom,#121212,#1a1a1a);color:#fff;overflow:hidden;z-index:100}.shared-playlist-header{flex-shrink:0;text-align:center;padding:1.5rem 1rem;background:linear-gradient(to bottom,rgba(29,185,84,.15),transparent)}.shared-badge{display:inline-flex;align-items:center;gap:.5rem;background:#1db95433;border:1px solid rgba(29,185,84,.3);padding:.4rem .85rem;border-radius:20px;font-size:.8rem;color:#1db954;font-weight:500;margin-bottom:.75rem}.shared-playlist-header h2{margin:.5rem 0;font-size:1.5rem;font-weight:700;color:#fff}.shared-playlist-date{color:#a0a0a0;font-size:.85rem;margin:0}.shared-playlist-content{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:0 1rem}.shared-playlist-songs{flex:1;overflow-y:auto;padding:.5rem 0;scrollbar-width:thin;scrollbar-color:#1db954 #2a2a2a}.shared-playlist-songs::-webkit-scrollbar{width:6px}.shared-playlist-songs::-webkit-scrollbar-track{background:#2a2a2a;border-radius:3px}.shared-playlist-songs::-webkit-scrollbar-thumb{background:#1db954;border-radius:3px}.shared-song-list{display:flex;flex-direction:column;gap:.75rem;padding:0;margin:0;list-style:none}.shared-playlist-footer{flex-shrink:0;padding:1rem 1rem 1.5rem;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);border-top:1px solid #2a2a2a}.songs-count{text-align:center;color:#888;margin:0 0 .75rem;font-size:.85rem}.owner-badge{text-align:center;color:#1db954;font-weight:600;margin:0 0 .75rem;font-size:.9rem}.shared-playlist-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center;color:#888}.shared-playlist-empty .empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.shared-playlist-empty p{margin:0;font-size:1rem}.shared-playlist-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center;flex:1}.error-icon{font-size:3rem;margin-bottom:1rem}.shared-playlist-error h2{margin:0 0 .5rem;color:#fff}.shared-playlist-error p{color:#a0a0a0;margin:0 0 1.5rem}.shared-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;color:#888}.login-required-content{text-align:center;padding:1rem 0}.login-icon{font-size:3rem;margin-bottom:1rem}.login-required-content p{color:#666;line-height:1.5;margin:0}html,body{margin:0;padding:0;height:100%;font-family:Arial,sans-serif}body{background:linear-gradient(to bottom,#121212,#1db954 80%);background-attachment:fixed;color:#fff;display:flex;justify-content:center;align-items:flex-start}#root{width:100%;height:100%}.container{width:100%;max-width:900px;display:flex;flex-direction:column;gap:1.5rem;margin:0 auto;padding:1rem 1rem 0}.tab-content{display:flex;flex-direction:column;gap:1rem}.form{display:flex;flex-direction:column;gap:.75rem}.songList{display:grid;grid-template-columns:1fr;gap:1rem;padding:0;overflow-y:auto;list-style:none;margin:0;border-radius:10px}.action-buttons{position:relative;display:flex;gap:10px;flex-wrap:wrap}.add-menu-dropdown{position:absolute;top:100%;left:0;margin-top:6px;background:#fff;border:1px solid #ccc;border-radius:6px;min-width:180px;z-index:1000;box-shadow:0 4px 10px #00000026;display:flex;flex-direction:column}.add-menu-dropdown button{padding:.6rem 1rem;background:none;border:none;text-align:left;cursor:pointer;color:#333;font-size:.9rem}.add-menu-dropdown button:hover{background-color:#f0f0f0}.state-message{padding:2rem;text-align:center;opacity:.8;font-size:1rem}.modal-hint{color:#666;font-size:.9rem;margin:0 0 1rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}
