@import"https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:wght@300;400;600;700&family=Fraunces:opsz,wght@9..144,600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #170e06;--color-bg-warm: #2d1810;--color-text: #f5e6d3;--color-text-muted: #c4a882;--color-accent: #d4763a;--color-accent-hover: #e8955a;--color-secondary: #8b5a2b;--color-border: rgba(212, 118, 58, .3);font-family:Nunito,system-ui,-apple-system,sans-serif;line-height:1.6;font-weight:400;color:var(--color-text);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-height:100vh;min-height:100dvh;background-color:var(--color-bg)}#root{min-height:100vh;min-height:100dvh}.landing-page{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(180deg,#170e06,#170e06b3 25% 75%,#170e06),url(/background2.png) center center / cover no-repeat fixed}.container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;padding:1.25rem 1.5rem;max-width:480px;max-height:650px;margin:0 auto;text-align:center}.landing-page .hero{display:block;text-align:center}.logo-wrapper{position:relative;display:inline-block;margin-bottom:1rem}.logo-wrapper:before{content:"";position:absolute;inset:-8px;border-radius:50%;background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-secondary) 50%,var(--color-accent) 100%);opacity:.6;filter:blur(12px);animation:pulse 3s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:.6}50%{transform:scale(1.05);opacity:.8}}.logo{position:relative;width:110px;height:110px;border-radius:50%;object-fit:cover;border:3px solid var(--color-accent);box-shadow:0 4px 20px #d4763a4d,0 0 40px #8b5a2b33}.title{font-family:Poetsen One,cursive;font-size:2.75rem;font-weight:400;letter-spacing:.02em;color:var(--color-text);margin-bottom:.125rem;text-shadow:0 2px 10px rgba(0,0,0,.3)}.tagline{font-size:.85rem;color:var(--color-text-muted);font-weight:300;letter-spacing:.15em;text-transform:uppercase}.content{display:flex;flex-direction:column;align-items:center;gap:1.75rem}.welcome{font-family:Inter,sans-serif;font-size:1em;line-height:1.8;color:var(--color-text);margin:20px 0;max-width:300px}.landing-links{display:flex;flex-direction:column;align-items:center;gap:.75rem;width:100%}.landing-link{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;padding:.75rem 1.25rem;border-radius:100px;text-decoration:none;font-weight:500;font-size:.95rem;transition:all .3s ease;width:100%;max-width:260px}.landing-link.primary{background:linear-gradient(135deg,#e8b923,#c49a1a);color:#1a1209;box-shadow:0 4px 15px #e8b92366,0 2px 4px #0003}.landing-link.primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #c9a22766,0 4px 8px #0000004d}.landing-link.primary:active{transform:translateY(0)}.landing-link.secondary{background:#ffffff14;color:var(--color-text);border:1px solid var(--color-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.landing-link.secondary:hover{background:#ffffff1f;border-color:var(--color-accent);color:var(--color-accent-hover)}.icon{width:20px;height:20px;flex-shrink:0}@supports (padding-bottom: env(safe-area-inset-bottom)){.container{padding-bottom:calc(2rem + env(safe-area-inset-bottom))}}@media(min-width:400px){.logo{width:120px;height:120px}.title{font-size:3rem}.welcome{font-size:1.1rem}}.rhythm-page{--note-open: #4ade80;--note-slap: #f97316;--note-bass: #8b5cf6;--note-bell: #fbbf24;--note-bass-open: #22d3ee;--note-bass-muffled: #6366f1;--note-default: #94a3b8;--font-display: "Fraunces", serif;--font-body: "Bricolage Grotesque", sans-serif;--bg: #0f0c08;--surface: rgba(20, 16, 12, .96);--surface-strong: rgba(26, 20, 15, .98);--surface-raised: rgba(32, 26, 20, .95);--surface-border: rgba(255, 198, 132, .15);--accent: #ff7a20;--accent-soft: rgba(255, 122, 32, .18);--text: #f4efe7;--text-muted: rgba(244, 239, 231, .7);--muted: rgba(244, 239, 231, .55);--shadow: 0 28px 60px rgba(0, 0, 0, .45);--shadow-soft: 0 18px 30px rgba(0, 0, 0, .25);font-family:Bricolage Grotesque,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#f4efe7;background-color:#0f0c08;min-height:100vh;position:relative;z-index:1;background:linear-gradient(180deg,#0f0c08d9,#0f0c08bf,#0f0c08e6),url(/background2.png) center center / cover no-repeat fixed}.rhythm-page button,.rhythm-page input{font-family:inherit}.rhythm-page button:focus-visible,.rhythm-page input:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.rhythm-page{@keyframes cardPulse{0%,to{box-shadow:0 0 0 1px var(--accent)}50%{box-shadow:0 0 0 2px var(--accent),0 0 12px #ff7a2033}}@keyframes statusPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}@keyframes loadingSlide{0%{transform:translate(-100%);width:30%}50%{width:60%}to{transform:translate(400%);width:30%}}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes sheetSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes rec-pulse{0%,to{border-color:#ef4444}50%{border-color:#ef44444d}}@keyframes pulse-border{0%,to{border-color:var(--accent)}50%{border-color:transparent}}}.rhythm-page .app{max-width:640px;margin:0 auto;padding:0 16px 80px}.rhythm-page .app-header{display:flex;align-items:center;flex-wrap:wrap;gap:12px;padding:16px 0;margin-bottom:24px;border-bottom:1px solid var(--surface-border);flex-shrink:0}.rhythm-page .app-header-tabs{display:flex;gap:4px;background:var(--surface);border-radius:10px;padding:3px}.rhythm-page .app-header-tab{padding:7px 16px;border-radius:8px;font-size:.85rem;font-weight:600;color:var(--muted);text-decoration:none;transition:background .12s,color .12s;display:flex;align-items:center}.rhythm-page .app-header-tab:hover{color:var(--text)}.rhythm-page .app-header-tab.active{background:var(--accent-soft);color:var(--accent)}.rhythm-page .filters{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.rhythm-page .search-row{display:flex;align-items:center}.rhythm-page .search-wrapper{flex:1;position:relative}.rhythm-page .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}.rhythm-page .search-input{width:100%;padding:10px 36px 10px 40px;background:var(--surface);border:1px solid var(--surface-border);border-radius:10px;font-size:.9rem;color:var(--text);outline:none;transition:border-color .2s,box-shadow .2s}.rhythm-page .search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.rhythm-page .search-input::placeholder{color:var(--muted)}.rhythm-page .search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--surface-strong);border:none;border-radius:50%;color:var(--text-muted);font-size:1rem;cursor:pointer;transition:background .2s,color .2s}.rhythm-page .search-clear:hover{background:var(--accent);color:#1a1a1a}.rhythm-page .filter-bar{display:flex;align-items:center;gap:8px}.rhythm-page .filter-fav-btn{height:36px;padding:0 14px;display:flex;align-items:center;justify-content:center;gap:4px;background:var(--surface);border:1px solid var(--surface-border);border-radius:8px;color:var(--muted);font-size:.9rem;cursor:pointer;transition:all .15s;flex-shrink:0}.rhythm-page .filter-fav-btn:hover{border-color:var(--accent);color:var(--text)}.rhythm-page .filter-fav-btn.active{background:var(--accent);border-color:var(--accent);color:#1a1a1a}.rhythm-page .filter-select{height:36px;flex:1;padding:0 28px 0 12px;background:var(--surface);border:1px solid var(--surface-border);border-radius:8px;color:var(--text);font-size:.85rem;font-family:inherit;cursor:pointer;outline:none;transition:border-color .15s;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23999' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.rhythm-page .filter-select:focus{border-color:var(--accent)}.rhythm-page .filter-select option{background:#1a1209;color:var(--text)}.rhythm-page .results-count{font-size:.8rem;color:var(--muted);white-space:nowrap;margin-left:auto}.rhythm-page .filter-reset{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--surface-border);border-radius:50%;font-size:.9rem;color:var(--text-muted);cursor:pointer;transition:all .15s}.rhythm-page .filter-reset:hover{border-color:var(--accent);color:var(--text)}.rhythm-page .error-banner{padding:14px 18px;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:12px;color:#fca5a5;margin-bottom:24px;font-size:.9rem}.rhythm-page .rhythm-grid{display:flex;flex-direction:column;gap:4px;animation:fadeIn .5s ease-out .2s both}.rhythm-page .rhythm-card{position:relative;display:flex;flex-direction:row;align-items:center;gap:12px;padding:8px 12px;background:var(--surface-strong);border:1px solid var(--surface-border);border-radius:8px;text-align:left;cursor:pointer;transition:border-color .2s,box-shadow .2s}.rhythm-page .rhythm-card:focus-visible{outline:2px solid rgba(255,122,32,.7);outline-offset:2px}.rhythm-page .rhythm-card:hover{border-color:#ff7a2066;box-shadow:0 4px 12px #00000026}.rhythm-page .rhythm-card.is-active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.rhythm-page .rhythm-card.is-playing{animation:cardPulse 2s ease-in-out infinite}.rhythm-page .rhythm-status{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:flex;align-items:center;gap:4px;font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:2px 8px;background:#ffffff14;border-radius:8px;pointer-events:none}.rhythm-page .rhythm-status.live{background:var(--accent);color:#1a1a1a}.rhythm-page .favorite-toggle{width:26px;height:26px;padding:0;border-radius:999px;border:1px solid rgba(255,255,255,.15);background:#ffffff1f;color:var(--text-muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0}.rhythm-page .favorite-toggle:hover{border-color:#ff7a2080;color:var(--text)}.rhythm-page .favorite-toggle.is-favorite{background:#ff7a2033;border-color:#ff7a20b3;color:var(--accent)}.rhythm-page .favorite-toggle:focus-visible{outline:2px solid rgba(255,122,32,.7);outline-offset:2px}.rhythm-page .status-dot{width:5px;height:5px;background:currentColor;border-radius:50%;animation:statusPulse 1s ease-in-out infinite}.rhythm-page .rhythm-name{font-size:.95rem;font-weight:600;margin:0;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.rhythm-page .rhythm-meta{font-size:.75rem;color:var(--text-muted);flex-shrink:0;margin-left:auto;white-space:nowrap}.rhythm-page .pattern-viz{position:relative;display:flex;flex-direction:column;gap:3px}.rhythm-page .pattern-viz.mini{gap:2px}.rhythm-page .pattern-viz.full{gap:6px}.rhythm-page .pattern-track{display:flex;align-items:center;gap:8px}.rhythm-page .pattern-viz.mini .pattern-track{gap:0}.rhythm-page .pattern-viz.full .pattern-track{gap:12px}.rhythm-page .pattern-track.muted{opacity:.35}.rhythm-page .track-label{width:64px;flex-shrink:0;display:flex;align-items:center;gap:4px;cursor:pointer;transition:opacity .15s}.rhythm-page .track-label:hover{opacity:.8}.rhythm-page .track-name{font-size:.7rem;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rhythm-page .track-status{display:none}.rhythm-page .track-notes{display:flex;gap:2px;flex:1}.rhythm-page .pattern-viz.full .track-notes{gap:3px}.rhythm-page .note-cell{flex:1;aspect-ratio:1;max-width:20px;display:flex;align-items:center;justify-content:center;border-radius:2px;transition:background .1s}.rhythm-page .pattern-viz.mini .note-cell{max-width:8px;aspect-ratio:1;border-radius:1px}.rhythm-page .note-cell.group-start{margin-left:4px}.rhythm-page .note-cell.group-start:first-child{margin-left:0}.rhythm-page .pattern-viz.mini .note-cell.group-start{margin-left:2px}.rhythm-page .pattern-viz.mini .note-cell.group-start:first-child{margin-left:0}.rhythm-page .note-cell.current{background:#fff3;box-shadow:0 0 8px #ff7a2066}.rhythm-page .note-cell.hit .note-dot{width:100%;height:100%;border-radius:inherit;background:var(--note-color, var(--note-default));opacity:.9;transition:transform .1s,opacity .1s}.rhythm-page .pattern-viz.mini .note-cell.hit .note-dot{opacity:.9}.rhythm-page .note-cell.current.hit .note-dot{opacity:1;transform:scale(1.15)}.rhythm-page .pattern-viz.full .note-cell{max-width:28px;border-radius:5px}.rhythm-page .pattern-viz.full .note-cell.rest{background:#ffffff06}.rhythm-page .pattern-viz.full .note-cell.hit .note-dot{border-radius:4px}.rhythm-page .playhead,.rhythm-page .pattern-viz.mini .playhead{display:none}.rhythm-page .empty-state{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;background:var(--surface);border:1px dashed var(--surface-border);border-radius:16px;text-align:center}.rhythm-page .empty-title{margin:0;font-size:1.1rem;color:var(--text)}.rhythm-page .empty-body{margin:8px 0 0;color:var(--text-muted);font-size:.9rem}.rhythm-page .empty-action{margin-top:16px;padding:10px 20px;background:var(--accent);border:none;border-radius:10px;color:#1a1a1a;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.rhythm-page .empty-action:hover{transform:translateY(-1px);box-shadow:0 4px 12px #ff7a204d}.rhythm-page .player{position:fixed;left:12px;right:12px;bottom:12px;background:var(--surface);border:1px solid var(--surface-border);border-radius:12px;padding:8px 12px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 -4px 32px #0000004d;z-index:100}.rhythm-page .player.is-playing{border-color:#ff7a204d}.rhythm-page .player-row{display:flex;align-items:center;gap:8px}.rhythm-page .player-info{display:flex;align-items:center;gap:8px;background:none;border:none;padding:0;cursor:pointer;text-align:left;color:inherit;min-width:0}.rhythm-page .player-info:disabled{cursor:default}.rhythm-page .player-name{font-size:.85rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rhythm-page .player-beat-indicator{display:flex;gap:4px;flex-shrink:0}.rhythm-page .beat-dot{width:6px;height:6px;background:#fff3;border-radius:50%;transition:background .1s,transform .1s}.rhythm-page .beat-dot.active{background:var(--accent);transform:scale(1.3)}.rhythm-page .player-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:none;cursor:pointer;flex-shrink:0;transition:transform .15s,box-shadow .15s}.rhythm-page .player-btn:disabled{opacity:.4;cursor:not-allowed}.rhythm-page .play-btn{background:var(--accent);color:#1a1a1a}.rhythm-page .play-btn:hover:not(:disabled){transform:scale(1.08);box-shadow:0 2px 12px #ff7a2066}.rhythm-page .stop-btn{width:30px;height:30px;background:var(--surface-strong);color:var(--text);border:1px solid var(--surface-border)}.rhythm-page .stop-btn:hover:not(:disabled){border-color:var(--accent)}.rhythm-page .player-tempo-inline{display:flex;align-items:center;gap:6px;margin-left:auto;flex-shrink:1;min-width:0}.rhythm-page .player-tempo-inline .tempo-slider{width:80px;height:3px;background:#ffffff1a;border-radius:2px;-webkit-appearance:none;appearance:none}.rhythm-page .player-tempo-inline .tempo-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;background:var(--accent);border-radius:50%;cursor:pointer}.rhythm-page .player-tempo-inline .tempo-value{font-size:.75rem;font-weight:600;min-width:28px;text-align:right;color:var(--text-muted)}.rhythm-page .player-expand-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid var(--surface-border);background:var(--surface-strong);color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:border-color .2s,color .2s}.rhythm-page .player-expand-btn:hover:not(:disabled){border-color:var(--accent);color:var(--text)}.rhythm-page .player-expand-btn:disabled{opacity:.4;cursor:not-allowed}.rhythm-page .player-loading{position:absolute;bottom:0;left:0;right:0;height:2px;overflow:hidden;border-radius:0 0 12px 12px}.rhythm-page .loading-bar{height:100%;background:var(--accent);animation:loadingSlide 1s ease-in-out infinite}.rhythm-page .full-player-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:200;display:flex;align-items:flex-end;justify-content:center;animation:overlayFadeIn .2s ease-out}.rhythm-page .full-player{width:100%;max-width:540px;max-height:90dvh;overflow-y:auto;background:var(--surface);border:1px solid var(--surface-border);border-radius:16px 16px 0 0;padding:8px 16px 24px;display:flex;flex-direction:column;gap:16px;animation:sheetSlideUp .25s ease-out}.rhythm-page .fp-handle-bar{width:36px;height:4px;background:#fff3;border-radius:2px;margin:0 auto 4px;flex-shrink:0}.rhythm-page .fp-header{display:flex;flex-direction:column;gap:4px}.rhythm-page .fp-title-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.rhythm-page .fp-name{font-family:var(--font-display);font-size:1.25rem;font-weight:700;margin:0;color:var(--text);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rhythm-page .fp-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid var(--surface-border);background:var(--surface-strong);color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:border-color .15s,color .15s}.rhythm-page .fp-close:hover{border-color:var(--accent);color:var(--text)}.rhythm-page .fp-info{color:var(--text-muted);font-size:.8rem;margin:0;line-height:1.4}.rhythm-page .fp-visualizer{background:#00000040;border-radius:10px;padding:10px;overflow:hidden}.rhythm-page .fp-visualizer .note-cell{max-width:none;aspect-ratio:auto;min-height:12px}.rhythm-page .fp-transport{display:flex;gap:8px}.rhythm-page .fp-btn{display:flex;align-items:center;justify-content:center;gap:6px;height:40px;padding:0 16px;border-radius:10px;border:1px solid var(--surface-border);background:var(--surface-strong);color:var(--text);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;transition:all .15s}.rhythm-page .fp-btn:disabled{opacity:.4;cursor:not-allowed}.rhythm-page .fp-play{flex:1;background:var(--accent);border-color:var(--accent);color:#1a1a1a}.rhythm-page .fp-play:hover:not(:disabled){box-shadow:0 2px 12px #ff7a2066}.rhythm-page .fp-stop{width:40px;padding:0}.rhythm-page .fp-stop:hover:not(:disabled){border-color:var(--accent)}.rhythm-page .fp-tempo{display:flex;align-items:center;gap:8px}.rhythm-page .fp-tempo-adj{width:32px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--surface-strong);border:1px solid var(--surface-border);border-radius:6px;color:var(--text);font-size:.75rem;font-weight:600;cursor:pointer;flex-shrink:0;transition:border-color .15s}.rhythm-page .fp-tempo-adj:hover{border-color:var(--accent)}.rhythm-page .fp-tempo-value{display:flex;align-items:baseline;gap:3px;flex-shrink:0}.rhythm-page .fp-tempo-number{font-size:1rem;font-weight:700;color:var(--text);min-width:28px;text-align:center}.rhythm-page .fp-tempo-unit{font-size:.65rem;color:var(--muted)}.rhythm-page .fp-tempo-slider{flex:1;height:3px;background:#ffffff14;border-radius:2px;-webkit-appearance:none;appearance:none;min-width:0}.rhythm-page .fp-tempo-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;background:var(--accent);border-radius:50%;cursor:pointer}.rhythm-page .fp-tempo-actions{display:flex;gap:4px;flex-shrink:0}.rhythm-page .fp-tempo-action{height:28px;padding:0 10px;background:var(--surface-strong);border:1px solid var(--surface-border);border-radius:6px;color:var(--text-muted);font-size:.7rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:border-color .15s,color .15s}.rhythm-page .fp-tempo-action:hover{border-color:var(--accent);color:var(--text)}.rhythm-page .fp-about{background:var(--surface-strong);border:1px solid var(--surface-border);border-radius:10px;overflow:hidden}.rhythm-page .fp-about summary{padding:10px 14px;cursor:pointer;font-size:.8rem;color:var(--text-muted);transition:color .15s}.rhythm-page .fp-about summary:hover{color:var(--text)}.rhythm-page .fp-about p{padding:0 14px 14px;margin:0;color:var(--text-muted);font-size:.8rem;line-height:1.5}@media(max-width:768px){.rhythm-page .app{padding:0 16px 80px}.rhythm-page .player-tempo-inline .tempo-slider{width:60px}.rhythm-page .full-player{max-width:100%;border-radius:14px 14px 0 0;padding:8px 12px 20px}}.rhythm-page .app.conductor{min-height:100dvh;padding-bottom:0;background:transparent;-webkit-user-select:none;user-select:none;display:flex;flex-direction:column}.rhythm-page .conductor-header{margin-bottom:0}.rhythm-page .conductor-title{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--text)}.rhythm-page .conductor-mode-switcher{display:flex;border:1px solid var(--surface-border);border-radius:20px;overflow:hidden}.rhythm-page .conductor-mode-option{padding:6px 14px;background:none;border:none;color:var(--muted);font-size:.8rem;font-weight:600;cursor:pointer;transition:background .12s,color .12s}.rhythm-page .conductor-mode-option.active{background:var(--accent-soft);color:var(--accent)}.rhythm-page .conductor-header-actions{display:flex;gap:8px}.rhythm-page .conductor-header-btn{background:none;border:none;color:var(--accent);font-size:.8rem;font-weight:600;cursor:pointer;padding:4px 0;white-space:nowrap}.rhythm-page .conductor-quick-slots{display:grid;grid-template-columns:repeat(3,1fr);flex-shrink:0;border-radius:10px;overflow:hidden;margin:8px 16px}.rhythm-page .conductor-slot{padding:10px 4px;background:var(--surface-raised);border:none;box-shadow:inset 0 0 0 .5px var(--surface-border);color:var(--text);font-size:.75rem;font-weight:600;cursor:pointer;transition:background .12s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-radius:0}.rhythm-page .conductor-slot:active{opacity:.7}.rhythm-page .conductor-slot.active{background:var(--accent-soft);color:var(--accent)}.rhythm-page .conductor-slot.browse{color:var(--muted)}.rhythm-page .rhythm-picker-overlay{position:fixed;inset:0;z-index:1000;background:var(--bg, #0d0a07);display:flex;flex-direction:column;overflow:hidden}.rhythm-page .rhythm-picker-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--surface-border);flex-shrink:0}.rhythm-page .rhythm-picker-title{font-family:var(--font-display);font-size:1.3rem;font-weight:700;color:var(--text)}.rhythm-page .rhythm-picker-close{background:none;border:none;color:var(--muted);font-size:1.8rem;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:8px;cursor:pointer;transition:background .15s,color .15s}.rhythm-page .rhythm-picker-close:hover{background:var(--surface-raised);color:var(--text)}.rhythm-page .rhythm-picker-scroll{flex:1;overflow-y:auto;padding:16px 20px 32px;-webkit-overflow-scrolling:touch}.rhythm-page .rhythm-picker-section-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.15em;color:var(--accent);margin-bottom:12px;margin-top:8px}.rhythm-page .rhythm-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-bottom:24px}.rhythm-page .rhythm-picker-card{display:flex;flex-direction:column;gap:4px;padding:16px 14px;background:var(--surface-raised);border:1px solid var(--surface-border);border-radius:12px;text-align:left;cursor:pointer;transition:background .15s,border-color .15s,transform .1s}.rhythm-page .rhythm-picker-card:hover{background:var(--accent-soft);border-color:#ff7a204d}.rhythm-page .rhythm-picker-card:active{transform:scale(.97)}.rhythm-page .rhythm-picker-card.active{border-color:var(--accent);background:var(--accent-soft)}.rhythm-page .rhythm-picker-card-name{font-weight:600;font-size:.95rem;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rhythm-page .rhythm-picker-card-detail,.rhythm-page .rhythm-picker-card-tempo{font-size:.75rem;color:var(--muted)}.rhythm-page .conductor-beat-row{display:flex;justify-content:center;align-items:center;gap:14px;padding:8px 0 12px;flex-shrink:0}.rhythm-page .conductor-beat-dot{width:12px;height:12px;border-radius:50%;background:#ffffff40;transition:background .08s,transform .08s}.rhythm-page .conductor-beat-dot.active{background:var(--accent)}.rhythm-page .conductor-beat-dot.downbeat{background:#f94;transform:scale(1.35)}.rhythm-page .conductor-layers{padding:0 16px 8px;display:flex;flex-direction:column;gap:6px}.rhythm-page .conductor-layer{display:flex;flex-direction:column;gap:6px;background:var(--surface);border:1px solid var(--surface-border);border-left:4px solid transparent;border-radius:12px;padding:12px 14px;cursor:pointer;transition:background .12s,border-color .12s;text-align:left;color:inherit;font:inherit;width:100%;-webkit-tap-highlight-color:transparent}.rhythm-page .conductor-layer:active{background:var(--surface-strong)}.rhythm-page .conductor-layer.active{background:#ff7a2014;border-left-color:var(--accent)}.rhythm-page .conductor-layer.solo-muted{opacity:.42}.rhythm-page .conductor-layer.solo-muted .conductor-layer-label,.rhythm-page .conductor-layer.solo-muted .conductor-dot.hit,.rhythm-page .conductor-layer.solo-muted .step-cell.on{filter:saturate(.45)}.rhythm-page .conductor-layer-header{display:flex;align-items:center;gap:10px}.rhythm-page .conductor-layer-dot{width:10px;height:10px;border-radius:50%;border:2px solid rgba(255,255,255,.2);flex-shrink:0;transition:background .12s,border-color .12s}.rhythm-page .conductor-layer-dot.on{background:var(--accent);border-color:var(--accent)}.rhythm-page .conductor-layer-label{font-size:.95rem;font-weight:600;color:var(--muted);transition:color .12s}.rhythm-page .conductor-layer.active .conductor-layer-label{color:var(--text)}.rhythm-page .conductor-pattern-dots{display:flex;gap:3px;padding-left:20px}.rhythm-page .conductor-dot{width:5px;height:5px;border-radius:50%;background:#ffffff24;flex-shrink:0}.rhythm-page .conductor-dot.dim{background:#fff3}.rhythm-page .conductor-dot.hit{background:var(--accent)}.rhythm-page .conductor-transport{display:flex;align-items:center;gap:8px;padding:12px 16px 16px}.rhythm-page .conductor-tempo-btn{width:36px;height:44px;border-radius:10px;background:var(--surface);border:1px solid var(--surface-border);color:var(--text);font-size:1.1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.rhythm-page .conductor-tempo-btn:active{background:var(--surface-strong)}.rhythm-page .conductor-tempo-compact{display:flex;align-items:center;gap:2px;flex-shrink:0}.rhythm-page .conductor-tempo-value{font-size:1.1rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text);min-width:40px;text-align:center}.rhythm-page .conductor-click-btn{height:44px;padding:0 16px;border-radius:10px;background:var(--surface);border:2px solid rgba(255,255,255,.1);color:#ffffff59;font-size:1rem;font-weight:600;cursor:pointer;transition:border-color .15s,color .15s;-webkit-tap-highlight-color:transparent}.rhythm-page .conductor-click-btn:active{background:var(--surface-strong)}.rhythm-page .conductor-click-btn.active{border-color:var(--accent);color:var(--accent)}.rhythm-page .conductor-play-btn{flex:1;height:44px;border-radius:10px;background:var(--accent);border:none;color:#fff;font-size:1.15rem;font-weight:700;letter-spacing:.1em;cursor:pointer;transition:background .15s;-webkit-tap-highlight-color:transparent}.rhythm-page .conductor-play-btn:active{opacity:.85}.rhythm-page .conductor-play-btn.stop{background:#c0392b}.rhythm-page .conductor-play-btn:disabled{opacity:.5;cursor:default}.rhythm-page .step-grid{display:flex;flex-direction:column;gap:2px;padding:4px 0 2px}.rhythm-page .step-grid-row{display:flex;align-items:center;gap:4px}.rhythm-page .step-grid-label{width:16px;font-size:.65rem;font-weight:700;text-align:center;flex-shrink:0;opacity:.6}.rhythm-page .step-grid-label.bass{color:#8b5cf6}.rhythm-page .step-grid-label.tone{color:#4ade80}.rhythm-page .step-grid-label.slap{color:#f97316}.rhythm-page .step-grid-cells{display:flex;flex:1;gap:2px}.rhythm-page .step-cell{flex:1;height:18px;min-width:0;border:none;border-radius:3px;background:#ffffff1f;cursor:pointer;padding:0;transition:background .06s}.rhythm-page .step-cell:hover{background:#ffffff1a}.rhythm-page .step-cell.beat-start{margin-left:3px}.rhythm-page .step-cell.on.bass{background:#8b5cf6}.rhythm-page .step-cell.on.tone{background:#4ade80}.rhythm-page .step-cell.on.slap{background:#f97316}.rhythm-page .step-cell.on.bass:hover{background:#7c4ddb}.rhythm-page .step-cell.on.tone:hover{background:#3dc972}.rhythm-page .step-cell.on.slap:hover{background:#e56b0e}.rhythm-page .step-cell.current{box-shadow:inset 0 0 0 1.5px #ffffff80}.rhythm-page .conductor-layer-toggle{width:10px;height:10px;border-radius:50%;border:2px solid rgba(255,255,255,.2);background:none;cursor:pointer;padding:0;flex-shrink:0;margin-right:10px;transition:background .12s,border-color .12s}.rhythm-page .conductor-layer-toggle.on{background:var(--accent);border-color:var(--accent)}.rhythm-page .conductor-layer-label.clickable{cursor:pointer}.rhythm-page .conductor-layer-label.clickable:hover{color:var(--text)}.rhythm-page .swipable-patterns{touch-action:pan-y;position:relative}.rhythm-page .pattern-dots{display:flex;align-items:center;justify-content:center;gap:8px;padding:6px 0 2px}.rhythm-page .pattern-dot{width:10px;height:10px;border-radius:50%;background:#ffffff26;cursor:pointer;transition:background .15s,transform .15s}.rhythm-page .pattern-dot:active{transform:scale(1.3)}.rhythm-page .pattern-dot.active{background:var(--accent)}.rhythm-page .pattern-dot.add{width:auto;height:auto;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:.7rem;color:#ffffff4d;border:1px dashed rgba(255,255,255,.15);background:none;cursor:pointer}.rhythm-page .pattern-dot-label{font-size:.7rem;color:var(--muted);margin-left:4px}.rhythm-page .conductor-solo-btn{height:22px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:#ffffff08;color:#ffffff80;font-size:.62rem;font-weight:700;letter-spacing:.03em;cursor:pointer;padding:0 10px;transition:border-color .08s,color .08s,background .08s;flex-shrink:0}.rhythm-page .conductor-solo-btn:hover{border-color:#ffffff38;color:#ffffffc7}.rhythm-page .conductor-solo-btn.active{border-color:#f59e0b;background:#f59e0b29;color:#fbbf24}.rhythm-page .conductor-mute-btn{height:22px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:#ffffff08;color:#ffffff80;font-size:.62rem;font-weight:700;letter-spacing:.03em;cursor:pointer;padding:0 10px;transition:border-color .08s,color .08s,background .08s;flex-shrink:0}.rhythm-page .conductor-mute-btn:hover{border-color:#ffffff38;color:#ffffffc7}.rhythm-page .conductor-mute-btn.active{border-color:#fff3;background:#ffffff14;color:var(--text)}.rhythm-page .conductor-add-track{display:flex;align-items:center;justify-content:center;height:44px;border-radius:12px;border:1px dashed rgba(255,255,255,.15);background:none;color:var(--muted);font-size:.85rem;font-weight:500;cursor:pointer;transition:border-color .12s,color .12s;width:100%}.rhythm-page .conductor-add-track:hover{border-color:var(--accent);color:var(--accent)}.rhythm-page .conductor-layer.rec-target{border-left-color:#ef4444;background:#ef44440f}.rhythm-page .conductor-rec-indicator{font-size:.6rem;font-weight:700;color:#ef4444;letter-spacing:.05em;animation:rec-pulse 1.5s infinite}.rhythm-page .conductor-delete-track{background:none;border:none;color:#ffffff40;font-size:1.1rem;cursor:pointer;padding:0 4px;line-height:1;transition:color .1s}.rhythm-page .conductor-delete-track:hover{color:#ef4444}.rhythm-page .conductor-track-empty{font-size:.7rem;color:#fff3;padding-left:20px}.rhythm-page .conductor-rec-hint{text-align:center;font-size:.8rem;color:var(--muted);padding:4px 16px;flex-shrink:0}.rhythm-page .conductor-rec-hint strong{color:var(--text)}.rhythm-page .conductor-rec-btn{height:44px;padding:0 16px;border-radius:10px;background:var(--surface);border:2px solid rgba(255,255,255,.1);color:#ffffff59;font-size:.85rem;font-weight:700;letter-spacing:.05em;cursor:pointer;transition:border-color .15s,color .15s;-webkit-tap-highlight-color:transparent}.rhythm-page .conductor-rec-btn:active{background:var(--surface-strong)}.rhythm-page .conductor-rec-btn.active{border-color:#ef4444;color:#ef4444;animation:rec-pulse 1.5s infinite}.rhythm-page .conductor-clear-rec{margin-left:auto;background:none;border:1px solid rgba(255,255,255,.15);color:var(--muted);font-size:.7rem;font-weight:500;padding:2px 8px;border-radius:6px;cursor:pointer}.rhythm-page .conductor-clear-rec:active{background:#ffffff0d}.rhythm-page .conductor-empty-layers{display:flex;align-items:center;justify-content:center;height:120px;color:var(--muted);font-size:.9rem;text-align:center;padding:0 24px}.rhythm-page .conductor-new-rhythm{padding:12px 16px 16px;border-bottom:1px solid var(--surface-border);display:flex;flex-direction:column;gap:10px;flex-shrink:0}.rhythm-page .conductor-new-row{display:flex;align-items:center;gap:12px}.rhythm-page .conductor-new-label{font-size:.8rem;color:var(--muted);width:40px;flex-shrink:0}.rhythm-page .conductor-new-options{display:flex;gap:6px;flex:1}.rhythm-page .conductor-new-opt{flex:1;height:36px;border-radius:8px;background:var(--surface);border:1px solid var(--surface-border);color:var(--muted);font-size:.85rem;font-weight:500;cursor:pointer;transition:border-color .12s,color .12s}.rhythm-page .conductor-new-opt.active{border-color:var(--accent);color:var(--accent)}.rhythm-page .conductor-new-create{height:40px;border-radius:10px;background:var(--accent-soft);border:1px solid rgba(255,122,32,.3);color:var(--accent);font-size:.85rem;font-weight:600;cursor:pointer;margin-top:4px}.rhythm-page .conductor-new-actions{display:flex;gap:8px;margin-top:4px}.rhythm-page .conductor-new-actions .conductor-new-create{flex:1;margin-top:0}.rhythm-page .conductor-new-create:active{background:#ff7a2040}.rhythm-page .conductor-new-create.tap-in{background:var(--surface-raised);border-color:var(--surface-border);color:var(--text)}.rhythm-page .tap-in-overlay{position:fixed;inset:0;z-index:1000;background:var(--bg, #0d0a07);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;padding:24px}.rhythm-page .tap-in-header{text-align:center}.rhythm-page .tap-in-title{display:block;font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text);margin-bottom:8px}.rhythm-page .tap-in-hint{font-size:.85rem;color:var(--muted)}.rhythm-page .tap-in-count{font-size:1.1rem;font-weight:600;color:var(--accent)}.rhythm-page .tap-in-pads{display:flex;gap:16px;width:100%;max-width:400px}.rhythm-page .tap-in-pad{flex:1;height:120px;border-radius:16px;border:2px solid var(--surface-border);background:var(--surface-raised);font-size:1.1rem;font-weight:700;cursor:pointer;transition:transform .08s,background .08s;-webkit-user-select:none;user-select:none;touch-action:manipulation}.rhythm-page .tap-in-pad:active{transform:scale(.93)}.rhythm-page .tap-in-pad.bass{color:var(--note-bass);border-color:var(--note-bass)}.rhythm-page .tap-in-pad.bass:active{background:#8b5cf633}.rhythm-page .tap-in-pad.tone{color:var(--note-open);border-color:var(--note-open)}.rhythm-page .tap-in-pad.tone:active{background:#4ade8033}.rhythm-page .tap-in-pad.slap{color:var(--note-slap);border-color:var(--note-slap)}.rhythm-page .tap-in-pad.slap:active{background:#f9731633}.rhythm-page .tap-in-actions{display:flex;gap:12px;width:100%;max-width:400px}.rhythm-page .tap-in-cancel{flex:1;height:52px;border-radius:12px;border:1px solid var(--surface-border);background:var(--surface-raised);color:var(--muted);font-size:1rem;font-weight:600;cursor:pointer}.rhythm-page .tap-in-done{flex:1.5;height:52px;border-radius:12px;border:none;background:var(--accent);color:#fff;font-size:1rem;font-weight:700;cursor:pointer}.rhythm-page .tap-in-done:disabled{opacity:.4;cursor:default}.rhythm-page .tap-in-midi{width:100%;max-width:400px;display:flex;flex-direction:column;gap:8px}.rhythm-page .tap-in-midi-select{width:100%;padding:8px 12px;background:var(--surface-raised);border:1px solid var(--surface-border);border-radius:8px;color:var(--text);font-size:.85rem}.rhythm-page .tap-in-midi-pads{display:flex;gap:6px}.rhythm-page .tap-in-midi-assign{flex:1;padding:8px 4px;background:var(--surface-raised);border:1px solid var(--surface-border);border-radius:8px;color:var(--muted);font-size:.7rem;cursor:pointer;transition:border-color .15s,color .15s;white-space:nowrap}.rhythm-page .tap-in-midi-assign.learning{border-color:var(--accent);color:var(--accent);animation:pulse-border 1s infinite}.rhythm-page .conductor-header-btn.danger{color:#ef4444b3}.rhythm-page .conductor-header-btn.danger:hover{color:#ef4444}@supports (padding-bottom: env(safe-area-inset-bottom)){.rhythm-page .conductor-transport{padding-bottom:calc(16px + env(safe-area-inset-bottom))}.rhythm-page .app-header{padding-top:calc(16px + env(safe-area-inset-top))}}.rhythm-page .rhythm-home{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;padding:32px 24px;max-width:420px;margin:0 auto}.rhythm-page .rhythm-home-header{text-align:center;margin-bottom:40px}.rhythm-page .rhythm-home-title{font-family:var(--font-display);font-size:clamp(2rem,6vw,2.8rem);font-weight:700;color:var(--text);margin:0}.rhythm-page .rhythm-home-subtitle{font-size:.85rem;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;margin-top:4px}.rhythm-page .rhythm-home-nav{display:flex;flex-direction:column;gap:16px;width:100%}.rhythm-page .rhythm-home-card{display:flex;flex-direction:column;gap:8px;padding:24px;background:var(--surface-raised);border:1px solid var(--surface-border);border-radius:16px;text-decoration:none;transition:background .15s,border-color .15s,transform .1s}.rhythm-page .rhythm-home-card:hover{background:var(--accent-soft);border-color:#ff7a204d}.rhythm-page .rhythm-home-card:active{transform:scale(.98)}.rhythm-page .rhythm-home-card-icon{font-size:1.6rem}.rhythm-page .rhythm-home-card-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--text)}.rhythm-page .rhythm-home-card-desc{font-size:.85rem;line-height:1.5;color:var(--muted)}.rhythm-page .rhythm-home-back{margin-top:40px;color:var(--muted);font-size:.85rem;text-decoration:none;transition:color .15s}.rhythm-page .rhythm-home-back:hover{color:var(--accent)}
