/*! modern-normalize v3.0.1 | MIT License | https://github.com/sindresorhus/modern-normalize */*,:before,:after{box-sizing:border-box}html{font-family:system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji";line-height:1.15;-webkit-text-size-adjust:100%;tab-size:4}body{margin:0}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-color:currentcolor}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,[type=button],[type=reset],[type=submit]{-webkit-appearance:button}legend{padding:0}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}:root{--bg-color: #f0f4f8;--panel-bg: #ffffff;--primary-color: #4a90e2;--accent-color-light: #ebf4ff;--accent-color-dark: #357abd;--text-color: #333;--text-color-light: #999;--border-radius: 16px;--box-shadow: 0 8px 25px rgba(0, 0, 0, .1);--flash-color: rgba(74, 144, 226, .2)}[data-theme=dark]{--bg-color: #1a202c;--panel-bg: #2d3748;--primary-color: #4a90e2;--accent-color-light: #4a5568;--accent-color-dark: #63b3ed;--text-color: #f7fafc;--text-color-light: #a0aec0;--box-shadow: 0 8px 25px rgba(0, 0, 0, .3);--flash-color: rgba(74, 144, 226, .15)}*,*:before,*:after{box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background-color:var(--bg-color);color:var(--text-color);margin:0;transition:background-color .3s ease,color .3s ease}.app-container{display:flex;flex-direction:column;min-height:100vh}.content-wrapper{flex-grow:1;display:flex;justify-content:center;align-items:center;padding:1rem}.app-header{padding:1rem 2rem;background-color:var(--panel-bg);box-shadow:0 2px 10px #0000000d;transition:background-color .3s ease;display:flex;justify-content:space-between;align-items:center}.app-title{margin:0;font-size:1.5rem;color:var(--primary-color);font-weight:700}.header-actions{display:flex;align-items:center;gap:1rem}.theme-toggle-button{background:none;border:none;cursor:pointer;padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--primary-color)}.theme-toggle-button:hover{background-color:var(--accent-color-light)}.theme-toggle-button .moon-icon{display:none}.theme-toggle-button .sun-icon,[data-theme=dark] .theme-toggle-button .moon-icon{display:block}[data-theme=dark] .theme-toggle-button .sun-icon{display:none}.vibeat-container{background-color:var(--panel-bg);padding:2rem;border-radius:var(--border-radius);box-shadow:var(--box-shadow);width:100%;max-width:520px;text-align:center;transition:box-shadow .1s ease-out,background-color .3s ease}.vibeat-container.playing{animation:beat-flash .1s ease-out}@keyframes beat-flash{0%{box-shadow:var(--box-shadow)}50%{box-shadow:0 8px 30px var(--flash-color)}to{box-shadow:var(--box-shadow)}}.accent-bars-container{display:flex;flex-direction:column;gap:10px;margin-bottom:2rem;min-height:180px;justify-content:center}.accent-bar-row{display:flex;justify-content:center;gap:10px;height:80px}.accent-bar{flex:1;background-color:var(--accent-color-light);border-radius:8px;display:flex;flex-direction:column;justify-content:flex-end;cursor:pointer;overflow:hidden;transition:transform .1s ease-out,box-shadow .1s ease-out,background-color .3s ease;position:relative}.accent-bar.active{transform:scale(1.05);box-shadow:0 0 12px 3px var(--primary-color);z-index:10}.accent-bar-inner{background-color:var(--primary-color);width:100%;transform-origin:bottom;transition:height .1s ease-out,background-color .3s ease}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:center;margin-top:0;margin-bottom:2.5rem;text-align:left}.setting-control{display:flex;flex-direction:column}.setting-control label{color:var(--text-color-light);font-size:.9rem;margin-bottom:.5rem;text-transform:uppercase}.beats-control{grid-column:1 / -1}.beats-control label{width:100%}.beats-value{color:var(--primary-color);font-weight:700}.subdivision-control{grid-column:1 / -1;align-items:center}.subdivision-selector{display:flex;gap:8px;width:100%;max-width:300px}.subdivision-selector button{flex:1;background-color:var(--accent-color-light);border:2px solid transparent;color:var(--primary-color);padding:.5rem;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s ease;font-size:.8rem}.subdivision-selector button:hover{border-color:var(--accent-color-dark)}.subdivision-selector button.active{background-color:var(--primary-color);color:#fff}.controls{display:flex;flex-direction:column;gap:1.25rem;align-items:center}.bpm-control-wrapper{display:flex;justify-content:center;align-items:center;gap:1.5rem;width:100%}.bpm-display{font-size:4.5rem;font-weight:700;color:var(--primary-color);line-height:1;margin-bottom:0;flex-grow:1;text-align:right;transition:color .1s ease}.bpm-label{font-size:1.5rem;font-weight:500;color:var(--text-color-light);margin-left:.25rem}.bpm-display.tapping{color:var(--accent-color-dark)}.tap-tempo-button{background-color:var(--accent-color-light);border:2px solid var(--accent-color-light);color:var(--primary-color);font-weight:600;font-size:1rem;border-radius:12px;padding:.75rem 1.5rem;cursor:pointer;transition:all .2s ease;flex-shrink:0;text-align:left}.tap-tempo-button:hover{border-color:var(--primary-color);background-color:var(--accent-color-light)}.tap-tempo-button:active{transform:scale(.95)}.bpm-slider,.beats-slider{-webkit-appearance:none;appearance:none;width:100%;height:8px;background:var(--accent-color-light);border-radius:5px;outline:none;cursor:pointer}.bpm-slider::-webkit-slider-thumb,.beats-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;background:var(--primary-color);border-radius:50%;cursor:pointer}.bpm-slider::-moz-range-thumb,.beats-slider::-moz-range-thumb{width:20px;height:20px;background:var(--primary-color);border-radius:50%;cursor:pointer;border:none}.play-pause-button{background-color:transparent;color:var(--primary-color);border:2px solid var(--primary-color);border-radius:50px;font-size:1.2rem;font-weight:600;padding:calc(1rem - 2px);cursor:pointer;transition:background-color .2s ease,color .2s ease;width:150px}.play-pause-button:hover,.play-pause-button.playing{background-color:var(--primary-color);color:#fff}.play-pause-button.playing:hover{background-color:var(--accent-color-dark);border-color:var(--accent-color-dark)}.share-button{background:none;border:none;color:var(--text-color-light);font-size:.9rem;font-weight:600;cursor:pointer;margin-top:-.5rem;padding:.5rem 1rem;border-radius:8px;transition:color .2s ease,background-color .2s ease}.share-button:hover{color:var(--primary-color);background-color:var(--accent-color-light)}.sidebar-toggle-button{background:var(--accent-color-light);border:none;border-radius:8px;color:var(--primary-color);font-weight:600;padding:.5rem 1rem;cursor:pointer;transition:background-color .2s ease}.sidebar-toggle-button:hover{background-color:var(--primary-color);color:var(--panel-bg)}.sidebar-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:100;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.sidebar-overlay.open{opacity:1;visibility:visible}.sidebar{position:fixed;top:0;right:0;width:360px;height:100%;background-color:var(--panel-bg);box-shadow:-5px 0 15px #0000001a;z-index:101;transform:translate(100%);transition:transform .3s ease;display:flex;flex-direction:column}.sidebar.open{transform:translate(0)}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--accent-color-light)}.sidebar-header h2{margin:0;color:var(--primary-color)}.close-button{background:none;border:none;font-size:2rem;color:var(--text-color-light);cursor:pointer}.sidebar-content{flex-grow:1;padding:1.5rem;overflow-y:auto}.save-preset-section{display:flex;align-items:center;gap:.75rem;margin-bottom:2rem}.save-preset-section input{flex-grow:1;padding:.75rem;border:1px solid var(--accent-color-light);border-radius:8px;background-color:var(--bg-color);color:var(--text-color);font-size:1rem;min-height:44px}.save-preset-section button{background-color:var(--primary-color);color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;cursor:pointer;font-weight:600;font-size:1rem;transition:background-color .2s ease}.save-preset-section button:hover{background-color:var(--accent-color-dark)}.no-presets{color:var(--text-color-light);text-align:center;margin-top:2rem}.preset-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-radius:8px;transition:background-color .2s ease}.preset-item:hover{background-color:var(--accent-color-light)}.preset-name{font-weight:600}.preset-actions{display:flex;gap:.5rem}.preset-actions button{background:none;border:1px solid var(--primary-color);color:var(--primary-color);border-radius:6px;padding:.25rem .75rem;cursor:pointer}.preset-actions button.delete{border-color:#e53e3e;color:#e53e3e}
