body{background-color:#1a1a1a;color:#fff;min-height:100vh;margin:0;padding:0}:root{--primary-color: #3f3f3f;--primary-color-dark: #2c2c2c;--text-color: #ffffff;--text-color-secondary: rgba(255, 255, 255, .7);--background-color: #1a1a1a;--card-background: rgba(255, 255, 255, .1);--border-color: rgba(255, 255, 255, .2)}.app h1{margin-top:1rem;padding-top:.5rem}.app{max-width:1280px;margin:0 auto;padding:2rem;text-align:center;background-color:#1a1a1a}.app-logo{max-width:235px;width:100%;height:auto;margin:1rem auto .5rem;padding-top:.5rem}.setup-container{display:flex;flex-direction:column;gap:2rem;width:100%;max-width:800px;margin:0 auto}.controls{margin-top:2rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.mode-header{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:1rem}.mode-title{color:#fffc;font-size:1.2rem;font-weight:500;margin:0}.mode-description{color:#fff9;font-size:.9rem;font-style:italic;max-width:600px;text-align:center;line-height:1.4}.app-tagline{font-size:1rem;color:#fff9;margin-bottom:1.5rem;font-style:italic;text-transform:uppercase;letter-spacing:.05em}@media screen and (max-width: 768px){.app{padding:1rem 1rem 2rem}.app-logo{max-width:175px;margin-top:0rem;margin-bottom:0rem;padding-top:2rem}.mode-description{font-size:.85rem;max-width:90%;padding:0 1rem}.compact-beat-selector{position:absolute;top:.75rem;right:.75rem;max-width:45%}.change-beat-button{padding:.3rem .6rem;font-size:.85rem}.app-tagline{font-size:.9rem}}@media screen and (max-width: 480px){.app{padding:.75rem .75rem 2rem}.app-logo{max-width:140px;margin-top:.5rem;padding-top:2.5rem}.mode-description{font-size:.8rem;padding:0 .5rem}.compact-beat-selector{top:.5rem;right:.5rem}.change-beat-button{padding:.25rem .5rem;font-size:.8rem}}@media screen and (max-width: 360px){.app{padding:.5rem .5rem 2rem}.app-logo{max-width:120px;margin-top:.25rem;padding-top:2.75rem}.mode-description{font-size:.75rem}.change-beat-button{padding:.2rem .4rem;font-size:.75rem}}.version-number{position:fixed;bottom:1rem;right:1rem;font-size:.8rem;color:#ffffff4d;z-index:1000;padding:.5rem;cursor:default;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.browser-warning{display:flex;align-items:flex-start;gap:1rem;background:#ff64641a;border:1px solid rgba(255,100,100,.3);border-radius:8px;padding:1.5rem;margin:2rem auto;max-width:600px;color:#ffffffe6}.browser-warning svg{flex-shrink:0;color:#ff6464}.browser-warning h3{margin:0 0 .5rem;font-size:1.1rem;color:#ff6464}.browser-warning p{margin:0;font-size:.9rem;line-height:1.4;color:#fffc}.recording-controls{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.recordings-button{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.5rem 1rem;color:#fffc;cursor:pointer;transition:all .2s ease}.recordings-button:hover{background:#ffffff1a}.training-header{position:fixed;top:1rem;right:1rem;z-index:1000;display:flex;align-items:center;gap:1rem}.recording-controls{position:fixed;top:1rem;left:50%;transform:translate(-50%);z-index:1000;display:flex;align-items:center;gap:1rem;background:#00000080;padding:.5rem 1rem;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.app .recording-controls,.app .record-toggle{display:none!important}.app.debug-mode .recording-controls,.app.debug-mode .record-toggle{display:flex!important}.training-mode{display:flex;flex-direction:column;align-items:center;gap:2rem;width:100%;margin:0 auto;position:relative}.training-mode:not(:has(.rhyme-map)){max-width:800px}.mode-header{width:100%;display:flex;align-items:center;justify-content:center;margin-bottom:1rem}.mode-title{color:#fffc;font-size:1.2rem;font-weight:500;text-align:center}.menu-button{position:fixed;top:1rem;left:1rem;z-index:1000;background:transparent;border:1px solid rgba(255,255,255,.2);color:#fff9;padding:.4rem .8rem;border-radius:4px;cursor:pointer;display:flex;align-items:center;gap:.4rem;font-size:.9rem;transition:all .2s ease}.menu-button:hover{background:#ffffff0d;color:#ffffffe6;border-color:#ffffff4d}.menu-button svg{width:14px;height:14px;opacity:.6;transition:all .2s ease}.menu-button:hover svg{opacity:.9}.controls{display:flex;gap:1rem;align-items:center}.bpm-controls{display:flex;align-items:center;gap:.5rem}.playback-controls{display:flex;gap:.5rem}.start-button{display:flex;align-items:center;justify-content:center;width:100%;max-width:200px;margin:1rem auto;padding:.75rem 1.5rem;font-size:1.1rem;font-weight:600;letter-spacing:.05em;color:#ffffffe6;background:#ffffff1a;border:2px solid rgba(255,255,255,.3);border-radius:6px;cursor:pointer;transition:all .2s ease}.start-button:hover:not(:disabled){background:#ffffff26;border-color:#fff6}.start-button.playing{background:#ffffff0d;border-color:#ffffff26;color:#fff9}.start-button.playing:hover:not(:disabled){background:#ffffff14;border-color:#fff3;color:#ffffffb3}.start-button:disabled{opacity:.7;cursor:wait}.start-button .loading-spinner{width:24px;height:24px;border:3px solid rgba(255,255,255,.1);border-top-color:#fff9;border-radius:50%;animation:spin 1s linear infinite}.hint-toggle .toggle-switch{position:relative;display:inline-block;width:50px;height:24px}.hint-toggle .toggle-switch input{opacity:0;width:0;height:0}.hint-toggle .toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#2e2e2e;transition:.4s;border-radius:24px}.hint-toggle .toggle-slider:before{position:absolute;content:"";height:16px;width:16px;left:4px;bottom:4px;background-color:#fff;transition:.4s;border-radius:50%}.hint-toggle input:checked+.toggle-slider{background-color:#2196f3}.hint-toggle input:checked+.toggle-slider:before{transform:translate(26px)}.hint-toggle .toggle-label{font-size:.9em;color:#666;-webkit-user-select:none;user-select:none}.rhyme-explorer{width:100%;max-width:900px;margin:0 auto;padding:1rem}.word-card,.main-word{display:none}.rhyme-explorer-stage{position:relative;width:min(100%,40vh);aspect-ratio:1 / 1;max-width:900px;margin:0 auto 1rem}.rhyme-progress-circle{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) scale(var(--circle-scale, 1));width:70%;height:70%;border-radius:50%;border:2px solid rgba(79,86,255,.35);box-shadow:0 0 0 1px #7c82ff26 inset;transition:transform .05s linear;pointer-events:none;z-index:1}.rhyme-lines{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0}.rhyme-line{stroke:#ffffff40;stroke-width:.6;vector-effect:non-scaling-stroke;opacity:0;animation:lineFade .35s ease-out both}@keyframes lineFade{0%{opacity:0}to{opacity:1}}.center-word{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:inline-flex;flex-direction:column;align-items:center;justify-content:center;max-width:80%;padding:1rem;background:#1f1f1f;border-radius:999px;box-shadow:0 10px 30px #00000040;z-index:2}.center-word h3{font-size:clamp(2rem,6vw,3.2rem);margin:0 0 .35rem;line-height:1;color:#fff;text-align:center}.center-word .group-label{display:none}.main-word h3{font-size:2rem;margin:0 0 .5rem;color:#fff}.main-word h3,.main-word .group-label{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.group-label{font-size:.9rem;color:#fff9;font-family:monospace}.rhyme-section{display:none}.rhyme-section h4{margin:0 0 1rem;color:#ffffffe6;font-size:1rem;text-align:center;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.themed-rhymes,.other-rhymes{display:none}.rhyme-bubbles{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1}.rhyme-bubble{position:absolute;transform:translate(-50%,-50%);min-width:96px;max-width:clamp(200px,34vw,360px);padding:.55rem .9rem;border-radius:999px;background:#2a2a2a;color:#fffffff5;font-size:clamp(1.6rem,4vw,2rem);text-align:center;display:inline-flex;align-items:center;justify-content:center;line-height:1.05;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border:1px solid rgba(0,0,0,.25);box-shadow:0 4px 14px #00000040;animation:bubblePop .35s ease-out both}.rhyme-bubbles.hints-visible{z-index:1}.rhyme-bubbles.hints-visible .rhyme-bubble{color:#dcdcdce6}.rhyme-bubble:hover{background:#ffffff2e}@keyframes bubblePop{0%{left:50%;top:50%;transform:translate(-50%,-50%) scale(.6);opacity:0}70%{left:var(--final-left, 50%);top:var(--final-top, 50%);transform:translate(-50%,-50%) scale(1.05);opacity:1}to{left:var(--final-left, 50%);top:var(--final-top, 50%);transform:translate(-50%,-50%) scale(1);opacity:1}}.slant-rhyme{background:#ffffff0f;color:#c8c8c8cc}.navigation-buttons{display:flex;gap:1rem;margin-top:1rem}.nav-button{display:flex;align-items:center;justify-content:center;gap:.5rem;background:#0000001a;border:2px solid rgba(255,255,255,.2);color:#ffffffe6;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;flex:1}.nav-button:hover{background:#ffffff26;border-color:#ffffff4d}.nav-button svg{width:20px;height:20px;opacity:.8}.prev-button{background:#ffffff0d}.next-button{background:#ffffff1a}.debug-word-list{position:fixed;bottom:0;left:0;right:0;background:#000c;padding:1rem;font-family:monospace;font-size:.8rem;color:#ffffffb3;max-height:200px;overflow-y:auto}.debug-word-list h4{margin:0 0 .5rem;font-size:.9rem;color:#ffffffe6}.word-list{display:flex;flex-wrap:wrap;gap:.5rem}.debug-word{background:#ffffff1a;padding:.2rem .4rem;border-radius:3px;font-size:.8rem;cursor:pointer;transition:all .2s ease}.debug-word:hover{background:#fff3}.debug-word.current{background:#4caf504d;color:#ffffffe6;font-weight:700}.debug-word.current:hover{background:#4caf5066}@media screen and (max-width: 768px){.rhyme-explorer-stage{aspect-ratio:1 / 1}.center-word{width:auto;min-width:0}.nav-button{padding:.5rem;width:40px;height:40px;min-width:40px;justify-content:center}.nav-button span{display:none}.nav-button svg{width:24px;height:24px;opacity:1;margin:0}}@media screen and (max-width: 480px){.center-word{width:auto;min-width:0;padding:1rem 1rem 1.5rem}.center-word h3{font-size:clamp(1.6rem,7vw,2.2rem)}.settings-row{flex-direction:row;align-items:flex-start;gap:1rem}.bars-per-round-setting label{flex-direction:column;align-items:flex-start;gap:.5rem}.settings-row>div:not(.bars-per-round-setting){display:flex;flex-direction:column;gap:.5rem;align-items:center;justify-content:flex-end;height:100%}.bars-per-round-setting select{width:100%}}@media screen and (max-width: 360px){.word-card{padding:.75rem;min-height:380px;gap:.5rem}.main-word{min-height:60px;padding-bottom:.5rem}.main-word h3{font-size:1.4rem}.rhyme-section{min-height:110px;padding:.5rem}.rhyme-list{min-height:60px}.rhyme{padding:.25rem .5rem;font-size:.8rem}}.settings-row{display:flex;align-items:center;gap:1rem;margin-top:1rem;margin-bottom:0;flex-wrap:wrap}.bars-per-round-setting{flex:0 1 auto}.settings-toggles{display:flex;align-items:center;gap:1rem;flex:1 1 auto;justify-content:flex-end}@media screen and (max-width: 768px){.settings-row{gap:.75rem}.settings-toggles{width:100%;justify-content:space-between}}@media screen and (max-width: 480px){.settings-row{flex-direction:column;align-items:stretch}.settings-toggles{justify-content:space-between}.bars-per-round-setting label{width:100%;justify-content:space-between}}.bars-per-round-setting label{display:flex;align-items:center;gap:.5rem;color:#ffffffe6;font-size:.9rem}.bars-per-round-setting select{background-color:#ffffff1a;color:var(--text-color, #fff);border:1px solid rgba(255,255,255,.2);border-radius:4px;padding:.5rem 2.5rem .5rem 1rem;font-size:1rem;cursor:pointer;transition:border-color .2s ease;min-width:120px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3e%3cpath d='M7 10l5 5 5-5z'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .7rem top 50%;background-size:1.2rem auto}.rhyme-explorer-progress-bar{position:absolute;bottom:0;left:50%!important;transform:translate(-50%);height:3px;background:linear-gradient(to right,#7c82ff,#4f56ff);transition:width .05s linear;border-radius:3px;max-width:calc(100% - 2.5rem)}.hint-toggle{display:flex;align-items:right;gap:10px;margin:10px 0}.rhyme-explorer .hint-toggle{align-items:center;flex-direction:row;flex-wrap:nowrap}.rhyme-explorer .hint-toggle label.toggle-switch,.rhyme-explorer .hint-toggle label.toggle-switch:hover{background:transparent!important;padding:0!important;border:none!important;box-shadow:none!important}.audio-toggle{display:flex;align-items:right;gap:10px;margin:10px 0}.toggle-switch{position:relative;display:inline-block;width:50px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#2e2e2e;transition:.4s;border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:16px;width:16px;left:4px;bottom:4px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.toggle-slider{background-color:#2196f3}input:checked+.toggle-slider:before{transform:translate(26px)}.toggle-label{font-size:.9em;color:#666;-webkit-user-select:none;user-select:none}.find-rhymes-container{position:relative;width:100%;max-width:800px;margin:0 auto;padding:1rem;box-sizing:border-box}.word-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,minmax(45px,auto));gap:8px;width:100%;max-width:600px;margin:0 auto}.target-word{position:relative;grid-column:2;grid-row:2;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--primary-color);padding:8px 6px;border-radius:10px;box-shadow:0 4px 15px #0003;z-index:10;min-height:45px;overflow:hidden;width:100%;box-sizing:border-box}.target-word h2{margin:0;color:#fff;font-size:clamp(.8em,3vw,1.2em);font-weight:700;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;min-width:0;padding:0}.word-button{padding:8px 6px;border:2px solid var(--primary-color);border-radius:10px;background:#ffffff1a;color:#ffffffe6;font-size:clamp(.8em,2.5vw,1em);cursor:pointer;transition:all .2s ease;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-height:45px;display:flex;align-items:center;justify-content:center;width:100%}.word-button:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 10px #0000001a;background:#ffffff26;z-index:5}.word-button:disabled{cursor:default;opacity:.8}.word-button.correct{background:#4caf50;color:#fff;border-color:#d0ffd1;font-weight:700;opacity:1}.word-button.correct.slant{background:#2e7d32;border-color:#2e7d32;color:#fff9}.word-button.incorrect{background:#f44336;color:#fff;border-color:#f44336;opacity:1}@keyframes fadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.word-button{animation:fadeIn .3s ease-out forwards}.word-button.hidden{background:#ffffff0d;border-color:#fff3;color:#ffffff4d;cursor:default}.word-button.hidden:hover{transform:none;box-shadow:none}.find-rhymes-progress-bar{position:absolute;bottom:0;left:50%!important;transform:translate(-50%);height:2px;background:linear-gradient(to right,#7c82ff,#4f56ff);transition:width 50ms linear}.settings-row{display:flex;justify-content:center;align-items:center;margin-top:1rem;margin-bottom:0;color:var(--text-color, #fff);padding:1rem;background:#ffffff0d;border-radius:8px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);gap:2rem}.bars-per-round-setting{display:flex;align-items:center;justify-content:center;width:100%}.bars-per-round-setting label{display:flex;align-items:center;justify-content:center;gap:1rem;font-size:1.1rem;font-weight:500}.bars-per-round-setting select{background-color:#ffffff1a;color:var(--text-color, #fff);border:1px solid rgba(255,255,255,.2);border-radius:4px;padding:.5rem 2.5rem .5rem 1rem;font-size:1rem;cursor:pointer;transition:border-color .2s ease;min-width:120px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3e%3cpath d='M7 10l5 5 5-5z'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .7rem top 50%;background-size:1.2rem auto}.rhyme-map{display:flex;flex-direction:column;gap:1rem;padding:1rem;height:100%;width:100%;overflow:hidden}.content-container{display:flex;flex-direction:column;gap:1rem;flex:1;overflow-x:auto;overflow-y:auto;min-height:0}.navigation-header{padding:.5rem}.back-button{background:#6e6e6e;border:2px solid #a2a2a2;border-radius:6px;padding:.75rem 2rem;cursor:pointer;font-size:1rem;font-weight:600;letter-spacing:.1em;color:#fff;transition:all .1s ease}.back-button:hover{background:transparent;border-color:#929292;color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}.pattern-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem;padding:.5rem;width:100%}.pattern-grid.root-view{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.pattern-card{background:var(--card-background);border:2px solid var(--border-color);border-radius:6px;padding:.5rem;cursor:pointer;transition:all .2s ease;text-align:center;min-width:0;display:flex;flex-direction:column;gap:.25rem}.pattern-card:not(.empty):hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a;border-color:var(--primary-color);filter:brightness(1.1)}.pattern-card.empty{cursor:default;opacity:.7}.pattern-card.empty h3,.pattern-card.empty .pattern-count{color:var(--text-color-secondary)}.pattern-card.selected{border-color:var(--primary-color);filter:brightness(1.1)}.pattern-card h3{margin:0;font-size:1.2rem;color:var(--text-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pattern-grid:not(.root-view) .pattern-card h3{font-size:.9rem}.pattern-count,.word-count{font-size:.8rem;color:var(--text-color)}.pattern-details{flex-shrink:0;background:var(--card-background);border:2px solid var(--border-color);border-radius:8px;padding:1rem;height:120px;width:100%;margin-bottom:1rem}.pattern-details h2{margin:0 0 .5rem;color:var(--primary-color);font-size:1.1rem}.word-list{display:flex;flex-wrap:wrap;gap:.5rem;overflow-y:hidden}.word{background:var(--background-color);padding:.25rem .75rem;border-radius:4px;font-size:.9rem;border:1px solid var(--border-color)}.more-words{color:var(--text-color-secondary);font-size:.9rem;font-style:italic;padding:.25rem .5rem}.placeholder-message{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-color-secondary);font-style:italic;font-size:1rem;text-align:center;padding:0 1rem}.pattern-grid.structured{display:flex;flex-direction:column;gap:1rem;padding:.5rem;width:fit-content;min-width:min(100%,1200px)}.vowel-group{display:grid;grid-template-columns:repeat(9,minmax(80px,1fr));gap:.5rem;padding:.5rem;background:var(--background-color);border-radius:8px;border:1px solid var(--border-color);width:100%}.pattern-grid.root-view .pattern-card{background:var(--card-background);border:2px solid var(--border-color);border-radius:6px;padding:.5rem;cursor:pointer;transition:all .2s ease;text-align:center}.pattern-grid.root-view .pattern-card h3{font-size:1.4rem;margin-bottom:.25rem}@media (max-width: 1200px){.vowel-group{grid-template-columns:repeat(9,minmax(70px,1fr))}}@media (max-width: 900px){.vowel-group{grid-template-columns:repeat(5,minmax(70px,1fr))}}@media (max-width: 600px){.vowel-group{grid-template-columns:repeat(3,minmax(70px,1fr))}}.pattern-details-modal{background:#191919f2;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:1.5rem;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);box-shadow:0 8px 32px #0003;animation:modalFade .2s ease-out;position:relative}.modal-close-button{position:absolute;top:.75rem;right:.75rem;width:2rem;height:2rem;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:#ffffff1a;color:var(--text-color);font-size:1.5rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close-button:hover{background:#fff3;border-color:#ffffff4d;transform:scale(1.1)}@keyframes modalFade{0%{opacity:0;transform:translate(-50%,-48%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.pattern-details-modal h2{margin:0 0 1rem;color:var(--text-color);font-size:1.2rem;text-align:center}.pattern-details-modal .word-list{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;max-height:60vh;overflow-y:auto;padding:.5rem;margin:0 -.5rem}.pattern-details-modal .word{background:#0000004d;padding:.4rem .8rem;border-radius:6px;font-size:.9rem;border:1px solid rgba(255,255,255,.2);color:var(--text-color);animation:wordFade .2s ease-out backwards}@keyframes wordFade{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.pattern-details-modal .word:nth-child(n+1):nth-child(-n+10){animation-delay:.05s}.pattern-details-modal .word:nth-child(n+11):nth-child(-n+20){animation-delay:.1s}.pattern-details-modal .word:nth-child(n+21):nth-child(-n+30){animation-delay:.15s}.pattern-details-modal .word:nth-child(n+31):nth-child(-n+40){animation-delay:.2s}.pattern-details-modal .word:nth-child(n+41){animation-delay:.25s}.pattern-details-modal .more-words{color:var(--text-color-secondary);font-size:.9rem;font-style:italic;padding:.5rem;width:100%;text-align:center;animation:wordFade .2s ease-out .3s backwards}.ending-dots{color:#fff6;font-weight:400;letter-spacing:1px;margin-right:2px}.pattern-card.empty .ending-dots{color:#fff3}.rhyme-search{width:100%;max-width:1080px;margin:0 auto;padding:20px}.collected-words-container{background:var(--surface-color, #2a2a2a);border-radius:12px;padding:15px;margin-bottom:20px;box-shadow:0 2px 8px #0003}.collected-words{display:flex;flex-direction:column;gap:12px;margin-bottom:12px}.collected-words-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:4px;border-radius:8px;background:var(--background-color)}.collected-word{background:var(--background-color);padding:6px 12px;border-radius:6px;font-size:16px;cursor:pointer;transition:all .2s ease;color:var(--text-color);border:1px solid var(--accent-color);opacity:.85}.collected-word.base-word{background:var(--accent-color);opacity:1;cursor:default;font-weight:600;border:2px solid var(--accent-color);box-shadow:0 1px 3px #0003;padding:8px 16px;font-size:17px;letter-spacing:.3px}.collected-word:not(.base-word){opacity:.75}.collected-word:not(.base-word):hover{background:var(--hover-color, #3a3a3a);transform:translateY(-1px);opacity:.9}.collected-words-actions{display:flex;gap:8px;justify-content:flex-end}.action-button{padding:6px 12px;font-size:14px;border-radius:6px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px;background:var(--background-color);color:var(--text-color);border:1px solid var(--accent-color)}.action-button:hover{background:var(--hover-color, #3a3a3a);transform:translateY(-1px)}.copy-button{background:var(--accent-color)}.clear-button{opacity:.8}.search-container{margin-bottom:30px;text-align:center}.search-input{width:100%;max-width:500px;padding:12px 20px;font-size:18px;border:2px solid #ccc;border-radius:8px;background-color:var(--background-color);color:var(--text-color);transition:border-color .3s ease}.search-input:focus{outline:none;border-color:var(--accent-color)}.error-message{color:var(--error-color, #ff4444);margin-top:10px;font-size:14px}.search-results{display:flex;flex-direction:column;gap:30px}.sort-controls{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:20px}.sort-button{padding:8px 16px;font-size:16px;background:var(--surface-color, #2a2a2a);border:2px solid var(--accent-color);border-radius:6px;color:var(--text-color);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px;opacity:.7;position:relative;min-width:160px;justify-content:center}.sort-button:hover{opacity:.9;transform:translateY(-1px)}.sort-button.active{background:var(--accent-color);opacity:1;transform:translateY(-1px);box-shadow:0 0 0 2px #fff}.sort-button.active:hover{transform:translateY(-2px)}@media (max-width: 600px){.sort-controls{flex-direction:column;width:100%;max-width:200px;margin-left:auto;margin-right:auto}.sort-button{width:100%;justify-content:center;padding:10px 20px}.word-count{display:none}.pattern-header{gap:8px;font-size:16px}.pattern-label{padding:3px 6px;font-size:13px}}.result-group{background:var(--surface-color, #2a2a2a);border-radius:12px;padding:20px;box-shadow:0 2px 8px #0003}.pattern-header{display:flex;align-items:center;gap:12px;margin-bottom:15px;font-size:18px;color:var(--text-color)}.pattern-label{font-family:monospace;background:var(--accent-color);padding:4px 8px;border-radius:4px;font-size:14px}.word-count{color:var(--text-secondary-color, #888);font-size:14px}.word-list{display:flex;flex-wrap:wrap;gap:10px}.word{background:var(--background-color);padding:6px 12px;border-radius:6px;font-size:16px;transition:all .2s ease;cursor:pointer}.word:hover{background:var(--hover-color, #3a3a3a);transform:translateY(-1px)}.word.collected{background:var(--accent-color);opacity:.8}.word.collected:hover{opacity:1}.more-words{color:var(--text-secondary-color, #888);font-size:14px;padding:6px 0}.slot-machine-container{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%;flex:1;min-height:400px;padding:1rem;perspective:1000px;max-width:1200px;margin:1rem auto 0;transform-origin:center top;position:relative;left:50%;transform:translate(-50%)}.slot-machines-wrapper{display:flex;justify-content:space-between;align-items:center;gap:1rem;width:100%}.slot-machine{position:relative;flex:1;min-width:0;display:flex;flex-direction:column;align-items:center}.slot-window{position:relative;height:300px;width:100%;overflow:hidden;margin:0 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(to bottom,#0000001a,#0000 20%,#0000 80%,#0000001a);border-radius:16px;box-shadow:inset 0 4px 8px #0000001a,inset 0 -4px 8px #0000001a}@media (max-width: 1200px){.slot-machine-container{transform:translate(-50%) scale(.85);min-height:340px;width:120%;margin-top:.5rem}}@media (max-width: 1000px){.slot-machine-container{transform:translate(-50%) scale(.7);min-height:280px;width:140%;margin-top:0}}@media (max-width: 800px){.slot-machine-container{transform:translate(-50%) scale(.6);min-height:240px;width:170%;margin-top:-.5rem}.slot-machine{min-width:200px}}@media (max-width: 600px){.slot-machine-container{transform:translate(-50%) scale(.5);min-height:200px;width:200%;margin-top:-1rem}.slot-machine{min-width:180px}.slot-item{font-size:1.8rem}.slot-item.current,.slot-item:nth-child(29){font-size:2.2rem}.slot-item[data-length=long]{font-size:1.4rem}.slot-item[data-length=very-long]{font-size:1.1rem}}@media (max-width: 480px){.slot-machine-container{transform:translate(-50%) scale(.45);width:220%}.slot-machine{min-width:160px}}@media (max-width: 360px){.slot-machine-container{transform:translate(-50%) scale(.4);width:250%}.slot-machine{min-width:150px}}.slot-list{position:absolute;display:flex;flex-direction:column;align-items:center;width:100%;transition:none;will-change:transform;transform:translateY(1450px)}.slot-item{height:100px;width:100%;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;text-transform:uppercase;color:var(--text-color, #fff);text-shadow:2px 2px 4px rgba(0,0,0,.1);transition:all .3s ease;padding:1rem;transform:translateY(-100px);opacity:.4}.slot-item.current,.slot-item:nth-child(29){font-size:2.5rem;color:var(--text-color, #fff);text-shadow:2px 2px 8px rgba(0,0,0,.2);filter:blur(0);transform:translateY(-100px) scale(1);opacity:1}.slot-item.current[data-length=long],.slot-item:nth-child(29)[data-length=long]{font-size:2rem}.slot-item.current[data-length=very-long],.slot-item:nth-child(29)[data-length=very-long]{font-size:1.6rem}.slot-item[data-length=long]{font-size:1.6rem}.slot-item[data-length=very-long]{font-size:1.3rem}.slot-item:not(.current):not(:nth-child(29)){filter:blur(1px);transform:translateY(-100px) scale(.8)}.slot-window.spinning .slot-list{transform:translateY(-1250px);filter:blur(5px);transition:transform 1s cubic-bezier(.5,0,0,1),filter .2s ease-in}.slot-window.spinning.ending-spin .slot-list{filter:blur(0px);transition:transform 1s cubic-bezier(.5,0,0,1),filter .2s ease-out}.navigation-buttons{display:flex;gap:1rem;margin-top:2rem}.nav-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1.2rem;border:none;border-radius:8px;background:var(--primary-color);color:#fff;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.nav-button:hover:not(:disabled){background:var(--primary-color-dark);transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.nav-button:disabled{background:var(--disabled-color, #ccc);cursor:not-allowed;transform:none;opacity:.7}.nav-button svg{width:24px;height:24px;transition:transform .2s ease}.nav-button:hover:not(:disabled) svg{transform:scale(1.1)}.slot-machine-settings{display:flex;justify-content:center;align-items:center;margin-top:2rem;color:var(--text-color, #fff);padding:1rem;background:#ffffff0d;border-radius:8px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.slot-machine-settings label{display:flex;align-items:center;gap:1rem;font-size:1.1rem;font-weight:500}.slot-machine-settings select{background-color:#ffffff1a;color:var(--text-color, #fff);border:1px solid rgba(255,255,255,.2);border-radius:4px;padding:.5rem 2.5rem .5rem 1rem;font-size:1rem;cursor:pointer;transition:border-color .2s ease;min-width:120px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3e%3cpath d='M7 10l5 5 5-5z'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .7rem top 50%;background-size:1.2rem auto}.slot-machine-settings select option{background-color:#2a2a2a;color:var(--text-color, #fff);padding:.5rem;border:none}.slot-machine-settings select:focus{outline:none;border-color:#fff6;box-shadow:0 0 0 2px #ffffff1a}.slot-machine-settings select:hover:not(:disabled){border-color:#ffffff4d}.slot-machine-settings select:disabled{opacity:.5;cursor:not-allowed}.slot-machine-progress-container{width:100%;height:4px;background:#ffffff1a;border-radius:2px;position:relative;overflow:hidden;margin-top:1rem}.slot-machine-progress-bar{position:absolute;top:0;left:50%;transform:translate(-50%);height:100%;background:linear-gradient(to right,#7c82ff,#4f56ff);border-radius:2px;transition:width 50ms linear}.rhyme-pattern{margin-top:1rem;display:flex;flex-direction:column;gap:1.5rem;width:100%;max-width:1000px;margin:1rem auto 0;text-transform:uppercase}.line{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1.5rem;width:100%;height:min-content}.line.next-word-row{margin-top:0;display:grid;grid-template-columns:repeat(4,minmax(0,1fr))}.line.next-word-row .block{visibility:hidden;box-shadow:none}.line.next-word-row .block:last-child{visibility:visible}.next-word-container{position:relative;grid-column:4}.next-word-container.entering .next-word-label,.next-word-container.entering .block.next-word{animation:nextLabelFade 2s ease-out!important}.next-word-label{position:absolute;top:.4rem;left:50%;transform:translate(-50%);font-size:.6rem;color:#ffffff4d;letter-spacing:.15em;font-weight:500;z-index:1}.block,.target-container{width:100%;height:45px;background-color:#2a2a2acc;border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:monospace;font-size:1.2rem;letter-spacing:.2em;transition:all .2s ease;box-shadow:0 0 20px #0000004d;padding:0}.block.active{background-color:#4a4a4a;box-shadow:0 0 20px #fff3;transform:scale(1.05);transition:all .2s cubic-bezier(.68,-.55,.265,1.55)!important}.block.question{background-color:#3b4165;font-weight:700;display:flex;align-items:center;justify-content:center;gap:.5rem}.block.question.active{background-color:#6571aa;box-shadow:0 0 20px #80b3ff66;transform:scale(1.05);transition:all .2s cubic-bezier(.68,-.55,.265,1.55)!important}@keyframes float1{0%,to{transform:translate(0) rotate(0)}50%{transform:translate(-2px,-4px) rotate(-3deg)}}@keyframes float2{0%,to{transform:translate(-1px,-2px) rotate(2deg)}50%{transform:translate(2px,2px) rotate(-2deg)}}@keyframes float3{0%,to{transform:translate(1px,2px) rotate(-2deg)}50%{transform:translate(-2px,-2px) rotate(3deg)}}@keyframes float4{0%,to{transform:translate(0) rotate(0)}50%{transform:translate(2px,4px) rotate(2deg)}}.floating-mark{display:inline-block;padding:0 .2em;transform-origin:center}.floating-mark:nth-child(1){animation:float1 2s ease-in-out infinite}.floating-mark:nth-child(2){animation:float2 2.2s ease-in-out infinite}.floating-mark:nth-child(3){animation:float3 1.8s ease-in-out infinite}.floating-mark:nth-child(4){animation:float4 2.4s ease-in-out infinite}.target-container{background:none;box-shadow:none}.target-container .block{width:100%;height:100%;margin:0}.block.target{background-color:#646cff;font-weight:700}.block.target.active{background-color:#7c82ff;box-shadow:0 0 20px #646cff66;transform:scale(1.05);transition:all .2s cubic-bezier(.68,-.55,.265,1.55)!important}.block.changing{animation:wordChange .3s cubic-bezier(.34,1.56,.64,1)!important}.block.question.changing.delay-1{animation-delay:.05s!important}.block.question.changing.delay-2{animation-delay:.1s!important}.block.question.changing.delay-3{animation-delay:.15s!important}.block.question.changing.delay-4{animation-delay:.2s!important}@keyframes wordChange{0%{transform:scale(1);opacity:1}40%{transform:scale(.8);opacity:.7}to{transform:scale(1);opacity:1}}.block.next-word{background-color:#646cff33;color:#fff9;font-family:monospace;font-size:1rem;letter-spacing:.15em;text-transform:uppercase;padding-top:.8rem;border:1px solid rgba(100,108,255,.5);box-shadow:0 0 15px #646cff1a}.block.next-word.entering{animation:none}@keyframes nextLabelFade{0%{opacity:0;transform:translate(-50%,5px)}to{opacity:1;transform:translate(-50%)}}@keyframes nextWordFade{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.next-word-container.entering .next-word-label{animation:nextLabelFade 2s ease-out!important}.next-word-container.entering .block.next-word{animation:nextWordFade 2s ease-out!important}.next-word-container.entering .next-word-label,.next-word-container.entering .block.next-word{animation:none}.next-word-container .next-word-label{transform:translate(-50%) translateY(0)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.rhyme-suggestion{font-size:1em;font-weight:400;color:#ffffffb3;text-transform:uppercase;letter-spacing:.05em}.settings-row{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;margin-bottom:0;color:var(--text-color, #fff);padding:1rem;background:#ffffff0d;border-radius:8px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);gap:2rem}.bars-per-round-setting{flex:1}.bars-per-round-setting label{display:flex;align-items:center;gap:1rem;font-size:1.1rem;font-weight:500}.bars-per-round-setting select{background-color:#ffffff1a;color:var(--text-color, #fff);border:1px solid rgba(255,255,255,.2);border-radius:4px;padding:.5rem 2.5rem .5rem 1rem;font-size:1rem;cursor:pointer;transition:border-color .2s ease;min-width:120px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3e%3cpath d='M7 10l5 5 5-5z'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .7rem top 50%;background-size:1.2rem auto}.bars-per-round-setting select option{background-color:#2a2a2a;color:var(--text-color, #fff);padding:.5rem;border:none}.bars-per-round-setting select:focus{outline:none;border-color:#fff6;box-shadow:0 0 0 2px #ffffff1a}.bars-per-round-setting select:hover:not(:disabled){border-color:#ffffff4d}.bars-per-round-setting select:disabled{opacity:.5;cursor:not-allowed}.hint-toggle{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.9em;color:#ffffffb3}.hint-toggle label{display:flex;align-items:center;gap:.8rem;cursor:pointer;-webkit-user-select:none;user-select:none;background:#ffffff1a;padding:.5rem 1rem;border-radius:4px;border:1px solid rgba(255,255,255,.2);transition:all .2s ease}.hint-toggle label:hover{background:#ffffff26;border-color:#ffffff4d}.hint-toggle input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:2.2rem;height:1.2rem;background:#fff3;border-radius:1rem;position:relative;cursor:pointer;transition:all .3s ease}.hint-toggle input[type=checkbox]:before{content:"";position:absolute;width:1rem;height:1rem;border-radius:50%;top:.1rem;left:.1rem;background:#ffffffe6;transition:all .3s ease}.hint-toggle input[type=checkbox]:checked{background:#fff9}.hint-toggle input[type=checkbox]:checked:before{left:1.1rem}@media screen and (max-width: 768px){.rhyme-pattern{margin-top:.5rem;gap:1rem}.line{gap:.75rem}.block,.target-container,.block.next-word{font-size:.9rem;height:40px;letter-spacing:.15em}.floating-mark{padding:0 .15em}.next-word-label{font-size:.55rem;top:.2rem}.block.next-word{font-size:.85rem;padding-top:.5rem}}@media screen and (max-width: 480px){.rhyme-pattern{margin-top:.25rem;gap:.75rem;margin-bottom:1rem}.line{gap:.5rem}.block,.target-container,.block.next-word{font-size:.8rem;letter-spacing:.1em;height:35px}.floating-mark{padding:0 .1em}.hint-toggle{flex-direction:column;align-items:center;width:100%}.hint-toggle label{flex-direction:column-reverse;align-items:center;gap:.5rem;padding:.75rem;width:100%}.hint-toggle input[type=checkbox]{align-self:center}.settings-row{flex-direction:row;align-items:flex-start;gap:1rem}.bars-per-round-setting label{flex-direction:column;align-items:flex-start;gap:.5rem}.bars-per-round-setting select{width:100%}.next-word-label{font-size:.5rem;top:.3rem}.block.next-word{font-size:.75rem;padding-top:.65rem}}@media screen and (max-width: 360px){.rhyme-pattern{gap:.5rem;margin-bottom:1.5rem}.line{gap:.4rem}.block,.target-container,.block.next-word{font-size:.75rem;letter-spacing:.08em;height:32px}.floating-mark{padding:0 .05em}.next-word-label{font-size:.45rem;top:.25rem}.block.next-word{font-size:.7rem;padding-top:.6rem}}.mode-selector{padding:20px;max-width:1200px;margin:0 auto}.mode-section{margin-bottom:60px}.mode-section:last-child{margin-bottom:0}.mode-section h2{color:#fff;margin-bottom:30px;font-size:1.8rem;text-align:center}.mode-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.mode-card{background:#ffffff1a;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0003;transition:transform .2s ease,box-shadow .2s ease;cursor:pointer}.mode-card:hover{transform:translateY(-4px);box-shadow:0 4px 12px #0000004d;background:#ffffff26}.mode-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.mode-icon{font-size:2rem}.difficulty-badge{padding:4px 12px;border-radius:20px;font-size:.9rem;font-weight:500}.difficulty-badge.easy{background-color:#4caf5033;color:#81c784}.difficulty-badge.medium{background-color:#ff980033;color:#ffb74d}.difficulty-badge.hard{background-color:#f4433633;color:#e57373}.mode-card h3{margin:0 0 10px;font-size:1.2rem;color:#fff}.mode-card p{margin:0;color:#fffc;font-size:.95rem;line-height:1.4}@media (max-width: 768px){.mode-selector{padding:15px}.mode-section{margin-bottom:40px}.mode-section h2{font-size:1.5rem;margin-bottom:20px}.mode-grid{grid-template-columns:1fr;gap:15px}.mode-card{padding:15px}.mode-icon{font-size:1.75rem}.mode-card h3{font-size:1.1rem}.mode-card p{font-size:.9rem}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#1a1a1a;border-radius:12px;border:1px solid rgba(255,255,255,.1);width:90%;max-width:600px;max-height:90vh;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.beats-list{padding:1.5rem;overflow-y:auto;display:flex;flex-direction:column;gap:1rem}.beat-item{display:flex;justify-content:space-between;align-items:left;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:1rem;gap:1rem}.beat-item.current{border-color:#ffffff4d;background:#ffffff14}.beat-item-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.beat-item-main{display:flex;align-items:center;gap:.5rem}.beat-item-name{color:#ffffffe6;font-size:1rem;font-weight:500}.beat-item-bpm{color:#ffffff80;font-size:.9rem}.beat-item-description{color:#ffffff80;font-size:.85rem;font-style:italic;text-align:left}.beat-item-controls{display:flex;align-items:center;gap:.75rem}.preview-button{width:36px;height:36px;border-radius:50%;border:2px solid rgba(255,255,255,.6);background:transparent;color:#fff9;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .2s ease}.preview-button:hover:not(:disabled){border-color:#ffffffe6;color:#ffffffe6}.preview-button svg{width:20px;height:20px}.preview-button.loading{cursor:wait}.loading-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.1);border-top-color:#fff9;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.select-button{background:transparent;border:1px solid rgba(255,255,255,.3);color:#fffc;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s ease;white-space:nowrap}.select-button:hover{background:#ffffff1a;border-color:#fff6}@media only screen and (max-width: 768px){.modal-overlay{padding:0}.modal-overlay .modal-content{width:100%!important;max-width:100%!important;height:100vh;max-height:100vh;border-radius:0;padding:.5rem!important;margin:0}.modal-overlay .modal-content>*{padding-left:0!important;padding-right:0!important}.modal-header,.beats-list{padding:1rem}.beat-item{padding:.75rem}.beat-item-controls{gap:.5rem}}.bpm-selector{display:inline-flex;align-items:center}.bpm-selector select{padding:.5rem;border-radius:4px;border:1px solid #ccc;background-color:#fff;font-size:1rem;cursor:pointer;min-width:120px}.bpm-selector select:disabled{cursor:not-allowed;color:#7c7c7c;opacity:.7}.bpm-selector select:focus{outline:none;border-color:#666;box-shadow:0 0 0 2px #0000001a}@media screen and (max-width: 400px){.bpm-selector select{min-width:120px}}.beat-selector-container{width:100%;margin-bottom:0rem}.beat-player{display:flex;align-items:center;gap:1rem;background:#ffffff0d;padding:1rem;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.play-button{width:48px;height:48px;padding:0;border:2px solid rgba(255,255,255,.6);background:transparent;border-radius:50%;color:#ffffffe6;cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative;transition:all .2s ease}.play-button svg{width:24px;height:24px}.play-button:hover{background:#ffffff1a;border-color:#fffc}.loading-spinner{width:24px;height:24px;border:2px solid rgba(255,255,255,.1);border-top:2px solid rgba(255,255,255,.9);border-radius:50%;animation:spin 1s linear infinite}.beat-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.beat-main-info{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.beat-label{color:#fff9;font-size:1rem}.beat-name{color:#ffffffe6;font-size:1rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.beat-details{display:flex;gap:1rem;color:#ffffff80;font-size:.85rem}.beat-description{font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.controls-group{display:flex;align-items:center;gap:.5rem}.change-beat-button{background:transparent;border:1px solid rgba(255,255,255,.3);color:#fffc;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s ease;white-space:nowrap;flex-shrink:0;min-width:120px}.change-beat-button:hover{background:#ffffff1a;border-color:#fff6}.controls-group select{background:transparent;border:1px solid rgba(255,255,255,.3);color:#fffc;padding:.5rem 2.5rem .5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s ease;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='rgba(255, 255, 255, 0.8)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .5rem center;background-size:1em;box-sizing:border-box}.controls-group select:hover{background-color:#ffffff1a;border-color:#fff6}.controls-group select:focus{outline:none;border-color:#ffffff80}.controls-group select option{background-color:#1a1a1a;color:#fffc}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.player-main-section{display:flex;align-items:center;gap:1rem;flex:1}@media screen and (max-width: 768px){.beat-label{display:none}.beat-player{padding:.75rem;gap:1rem;align-items:center}.player-main-section{display:flex;align-items:center;gap:1rem;flex:1;min-width:0;flex-wrap:wrap}.play-button{width:40px;height:40px;flex-shrink:0}.play-button svg{width:20px;height:20px}.beat-info{flex:1;min-width:0}.beat-name,.beat-description{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.controls-group{display:flex;gap:.5rem;flex-wrap:wrap}.change-beat-button{width:120px;height:35px;box-sizing:border-box;padding:0;line-height:35px}.controls-group select{width:120px!important;height:35px;box-sizing:border-box;padding:0 2.5rem 0 1rem;line-height:35px;margin:0}}@media screen and (max-width: 480px){.player-main-section{gap:.75rem}.beat-info{width:100%}.beat-details{margin-top:.25rem}.controls-group{width:100%;display:flex;gap:.5rem}.change-beat-button{flex:1}.controls-group select{flex-shrink:0}}.compact-beat-selector{display:flex;align-items:center;gap:.5rem;padding:.5rem;background-color:#0003;border-radius:4px}.compact-beat-selector .current-beat{display:flex;align-items:center;gap:.5rem;background-color:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;font-size:1rem;padding:.3rem .5rem;cursor:pointer;border-radius:4px;transition:all .2s}.compact-beat-selector .current-beat:hover:not(:disabled){background-color:#ffffff26;border-color:#ffffff4d}.compact-beat-selector .current-beat:disabled{opacity:.5;cursor:not-allowed}.compact-beat-selector .current-beat .dropdown-icon{width:16px;height:16px;opacity:.7;transition:opacity .2s}.compact-beat-selector .current-beat:hover:not(:disabled) .dropdown-icon{opacity:1}.compact-beat-selector .bpm-selector{margin:0}.compact-beat-selector .bpm-selector select{background-color:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);font-size:.9rem;padding:.3rem 2rem .3rem .5rem;cursor:pointer;transition:all .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3e%3cpath d='M7 10l5 5 5-5z'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .5rem center;background-size:1.2em}.compact-beat-selector .bpm-selector select:hover:not(:disabled){background-color:#ffffff26;border-color:#ffffff4d}.compact-beat-selector .bpm-selector select:disabled{background-color:#ffffff0d;color:#ffffff80;cursor:not-allowed}.compact-beat-selector .bpm-selector select:focus{border-color:#fff6;box-shadow:0 0 0 2px #ffffff1a}.compact-beat-selector .bpm-selector select option{background-color:#1a1a1a;color:#fff;padding:.5rem}.compact-beat-selector .mute-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fffc;border-radius:4px;cursor:pointer;transition:all .2s;padding:0}.compact-beat-selector .mute-button svg{width:20px;height:20px}.compact-beat-selector .mute-button:hover:not(:disabled){background-color:#ffffff26;border-color:#ffffff4d}.compact-beat-selector .mute-button:disabled{opacity:.5;cursor:not-allowed}.compact-beat-selector .mute-button.muted{background-color:#17171733;border-color:#8686864d;color:#727272cc}.compact-beat-selector .mute-button.muted:hover:not(:disabled){background-color:#51515140;border-color:#96969666}@media screen and (max-width: 768px){.compact-beat-selector{padding:0;background-color:transparent;gap:0;width:40px;min-width:40px}.compact-beat-selector .current-beat{padding:.5rem;width:40px;height:40px;min-width:40px;display:flex;align-items:center;justify-content:center;border-radius:4px;line-height:1;margin:0}.compact-beat-selector .current-beat span,.compact-beat-selector .current-beat .dropdown-icon{display:none}.compact-beat-selector .current-beat:before{content:"♪";font-size:1.5rem;display:flex;align-items:center;justify-content:center}.compact-beat-selector .bpm-selector,.compact-beat-selector .mute-button{display:none}}.custom-vocabulary-editor{max-width:600px!important}.editor-content{padding:20px;display:flex;flex-direction:column;gap:20px}.name-input-container,.word-list-container{display:flex;flex-direction:column;gap:8px}.name-input-container label,.word-list-container label{font-weight:500;color:var(--text-color)}.name-input-container input{padding:8px 12px;border:1px solid var(--border-color);border-radius:4px;font-size:14px;background:var(--background-color);color:var(--text-color)}.word-list-container textarea{padding:12px;border:1px solid var(--border-color);border-radius:4px;font-size:14px;resize:vertical;min-height:200px;background:var(--background-color);color:var(--text-color);font-family:monospace}.editor-controls{display:flex;justify-content:flex-end;padding-top:10px}.save-button{padding:8px 16px;background-color:var(--primary-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:background-color .2s}.save-button:hover:not(:disabled){background-color:var(--primary-color-dark)}.save-button:disabled{background-color:var(--disabled-color);cursor:not-allowed}@media (prefers-color-scheme: dark){.name-input-container input,.word-list-container textarea{border-color:var(--border-color-dark)}}.vocabulary-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;justify-content:center;align-items:center;z-index:1000}.vocabulary-modal-content{background:#1a1a1a;padding:1.5rem;border-radius:12px;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;position:relative;border:1px solid rgba(255,255,255,.1)}.vocabulary-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid var(--border-color)}.vocabulary-modal-header h2{margin:0;font-size:1.25rem;color:var(--text-color)}.close-button{background:none;border:none;font-size:1.5rem;color:var(--text-color);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px}.close-button:hover{background-color:var(--hover-color)}.vocabulary-modal-actions{padding:16px 20px}.vocabulary-filter-section{padding:1rem;border-bottom:1px solid var(--border-color)}.filter-toggle{display:flex;align-items:center;width:100%;background:none;border:none;color:var(--text-primary);cursor:pointer;padding:.5rem;text-align:left;font-size:1rem}.filter-toggle:hover{background:#ffffff0d}.filter-title{font-weight:500;flex:1}.filter-stats{color:var(--text-secondary);font-size:.9em;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.caret{font-size:.8em;transition:transform .2s ease;margin-right:.5rem}.caret.open{transform:rotate(180deg)}.filter-content{max-height:0;overflow:hidden;transition:max-height .3s ease-out;background:#ffffff08;border-radius:8px;margin-top:.5rem}.filter-content.open{max-height:200px}.filter-content-inner{padding:1rem}.filter-group{margin-bottom:1.5rem}.filter-group:last-child{margin-bottom:0}.filter-group-header{margin-bottom:1rem}.filter-group-title{font-size:.9rem;color:var(--text-secondary);font-weight:500}.syllable-range-controls{position:relative;padding:.5rem;display:flex;flex-direction:column;gap:.5rem;height:100px}.syllable-range-controls:before{content:"";position:absolute;left:8px;right:8px;top:18px;height:4px;background:#ffffff1a;border-radius:2px}.syllable-range-controls input[type=range]{position:absolute;width:calc(100% - 16px);left:8px;pointer-events:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;background:transparent}.syllable-range-controls input[type=range]:nth-child(1){top:18px}.syllable-range-controls input[type=range]:nth-child(3){top:18px}.syllable-range-controls input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;pointer-events:auto;width:16px;height:16px;border-radius:50%;background:#1a1a1a;border:2px solid rgba(255,255,255,.9);cursor:pointer;transition:all .2s ease;margin-top:-6px}.syllable-range-controls input[type=range]::-moz-range-thumb{pointer-events:auto;width:16px;height:16px;border-radius:50%;background:#1a1a1a;border:2px solid rgba(255,255,255,.9);cursor:pointer;transition:all .2s ease}.syllable-range-controls input[type=range].equal-values.min::-webkit-slider-thumb{transform:translate(-8px)}.syllable-range-controls input[type=range].equal-values.max::-webkit-slider-thumb{transform:translate(8px)}.syllable-range-controls input[type=range].equal-values.min::-moz-range-thumb{transform:translate(-8px)}.syllable-range-controls input[type=range].equal-values.max::-moz-range-thumb{transform:translate(8px)}.syllable-range-controls input[type=range]:hover::-webkit-slider-thumb{background:#ffffffe6}.syllable-range-controls input[type=range]:hover::-moz-range-thumb{background:#ffffffe6}.syllable-range-controls input[type=range]::-webkit-slider-runnable-track{width:100%;height:4px;background:transparent;border-radius:2px}.syllable-range-controls input[type=range]::-moz-range-track{width:100%;height:4px;background:transparent;border-radius:2px}.range-values{position:absolute;width:100%;display:flex;justify-content:center;align-items:center;gap:8px;top:40px;color:#ffffffb3;font-size:14px}.vocabulary-modal-footer{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:center}.create-vocabulary-button{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#ffffffe6;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s}.create-vocabulary-button:hover{background:#ffffff26;border-color:#ffffff4d}.vocabulary-list{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.vocabulary-item{display:flex;align-items:flex-start;flex-direction:row!important;gap:1rem;background:#ffffff0d;padding:1rem;border-radius:8px;border:1px solid rgba(255,255,255,.1);cursor:pointer;transition:background-color .2s;position:relative}.vocabulary-item:hover{background-color:var(--hover-color)}.vocabulary-item.selected{border-color:#fffc;border-width:2px;background:#ffffff14}.vocabulary-icon-container{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.vocabulary-info{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.vocabulary-modal-name{font-weight:500;color:var(--text-color);font-size:1rem;overflow:hidden;text-overflow:ellipsis}.vocabulary-description{font-size:.875rem;color:var(--text-secondary)}.vocabulary-actions{display:flex;gap:8px;margin-left:auto;padding-left:16px}.edit-button,.delete-button{background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;font-size:1rem;display:flex;align-items:center;justify-content:center;opacity:.7;transition:opacity .2s,background-color .2s}.edit-button:hover,.delete-button:hover{opacity:1;background-color:var(--hover-color)}.delete-button:hover{color:var(--error-color)}.vocabulary-link{display:inline;margin-top:4px;color:#06c;text-decoration:none;font-size:.9em;pointer-events:auto;width:fit-content;white-space:nowrap}.vocabulary-link:hover{text-decoration:underline}@media (prefers-color-scheme: dark){.vocabulary-modal-content{border:1px solid var(--border-color-dark)}}@media only screen and (max-width: 768px){.vocabulary-modal-overlay{padding:0}.vocabulary-modal-content{width:100%!important;max-width:100%!important;height:100vh;max-height:100vh;border-radius:0;padding:.5rem!important;margin:0}.vocabulary-modal-header{padding:1rem;margin-bottom:1rem}.vocabulary-list{grid-template-columns:1fr;gap:.75rem;padding:0 .5rem}.vocabulary-item{padding:.75rem}}.current-selection{display:flex;align-items:center;gap:.5rem;font-size:.9em;color:var(--text-secondary)}.current-selection-label{color:var(--text-secondary)}.current-selection-name{color:var(--text-primary);font-weight:500}.done-button{background-color:var(--primary-color);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .2s}.done-button:hover{background-color:var(--primary-color-dark)}.create-vocabulary-item{background:#ffffff08;border:2px dashed rgba(255,255,255,.2);transition:all .2s ease}.create-vocabulary-item:hover{background:#ffffff0d;border-color:#ffffff4d}.create-vocabulary-item .vocabulary-icon{color:#fff9;font-size:1.5rem}.create-vocabulary-item:hover .vocabulary-icon,.create-vocabulary-item .vocabulary-modal-name{color:#fffc}.create-vocabulary-item .vocabulary-description{color:#ffffff80}.vocabulary-selector-container{width:100%;margin-bottom:0rem}.vocabulary-player{display:flex;align-items:center;gap:1rem;background:#ffffff0d;padding:1rem;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.vocabulary-icon-container{width:48px;height:48px;border-radius:50%;border:2px solid rgba(255,255,255,.6);background:transparent;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s ease}.vocabulary-icon{font-size:1.5rem;color:#ffffffe6}.vocabulary-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.vocabulary-main-info{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.vocabulary-label{color:#fff9;font-size:1rem}.vocabulary-name{color:#ffffffe6;font-size:1rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vocabulary-details{display:flex;gap:1rem;color:#ffffff80;font-size:.85rem}.vocabulary-description{font-style:italic}.vocabulary-controls{display:flex;gap:.5rem;align-items:center}.change-vocabulary-button,.randomize-vocabulary-button{background:transparent;border:1px solid rgba(255,255,255,.3);color:#fffc;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s ease;white-space:nowrap;flex-shrink:0;display:flex;align-items:center;justify-content:center}.randomize-vocabulary-button{padding:.5rem}.randomize-vocabulary-button svg{width:20px;height:20px}.change-vocabulary-button:hover,.randomize-vocabulary-button:hover{background:#ffffff1a;border-color:#fff6}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#1a1a1a;border-radius:12px;border:1px solid rgba(255,255,255,.1);padding:2rem;max-width:800px;width:90%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h2{margin:0;color:#ffffffe6;font-size:1.5rem}.close-button{background:transparent;border:none;color:#fff9;font-size:1.5rem;cursor:pointer;padding:.5rem;line-height:1;border-radius:4px}.close-button:hover{background:#ffffff1a;color:#ffffffe6}.vocabulary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.vocabulary-item{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;text-align:left;cursor:pointer;transition:all .2s}.vocabulary-item:hover{transform:translateY(-2px);background:#ffffff14;border-color:#fff3}.vocabulary-item.current{border-color:#ffffff4d;background:#ffffff14}.vocabulary-meta{margin-top:auto;display:flex;justify-content:space-between;align-items:center}@media screen and (max-width: 768px){.vocabulary-label{display:none}.vocabulary-player{padding:.75rem}.vocabulary-controls{flex-wrap:wrap;justify-content:center;gap:.75rem}}@media screen and (max-width: 480px){.vocabulary-player{flex-wrap:wrap;gap:.75rem}.vocabulary-info{width:100%}.vocabulary-details{margin-top:.25rem}.vocabulary-controls{width:100%;display:flex;gap:.5rem}.change-vocabulary-button{flex:1}.randomize-vocabulary-button{flex-shrink:0}}.language-toggle{position:absolute;top:.5rem;right:.5rem;display:flex;gap:.25rem;background:#0000001a;padding:.2rem;border-radius:.25rem}.language-button{background:transparent;border:1px solid rgba(255,255,255,.1);color:#fff6;padding:.15rem .35rem;border-radius:.2rem;cursor:pointer;font-size:.75rem;transition:all .2s ease}.language-button:hover{background:#ffffff0d;color:#ffffffe6}.language-button.active{background:#ffffff1a;color:#ffffffe6;border-color:#fff3}.instagram-link{position:fixed;top:1rem;left:1rem;z-index:1000;color:#fff9;font-size:1.5rem;transition:all .2s ease;padding:.5rem;border-radius:50%;background:#0000001a;display:flex;align-items:center;justify-content:center}.instagram-link:hover{color:#ffffffe6;transform:scale(1.1);background:#0003}@media (max-width: 768px){.instagram-link{font-size:1.25rem;top:.75rem;left:.75rem}}@media (max-width: 480px){.instagram-link{font-size:1.1rem;top:.5rem;left:.5rem}}.record-toggle{display:flex;align-items:center;gap:.5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.5rem 1rem;color:#fffc;cursor:pointer;transition:all .2s ease}.record-toggle:hover{background:#ffffff1a}.record-toggle.enabled{background:#ff32321a;border-color:#ff32324d;color:#ff6464}.record-toggle.enabled:hover{background:#ff323226}.record-toggle .record-dot{opacity:0;transition:opacity .2s ease}.record-toggle.enabled .record-dot{opacity:1}.recordings-modal{background:#000000f2;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:2rem;width:90%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;gap:1.5rem}.recordings-list{overflow-y:auto;display:flex;flex-direction:column;gap:1rem}.recording-item{display:flex;align-items:center;justify-content:space-between;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:1rem;gap:1rem}.recording-info{display:flex;flex-direction:column;gap:.5rem}.recording-date{font-size:.9rem;color:#fff9}.recording-details{display:flex;flex-direction:column;gap:.25rem}.recording-beat{font-size:1rem;color:#ffffffe6;font-weight:500}.recording-mode{font-size:.9rem;color:#fffc}.recording-vocabulary{font-size:.9rem;color:#ffffffb3}.play-button{background:transparent;border:1px solid rgba(255,255,255,.2);color:#fffc;padding:.5rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;width:48px;height:48px;min-width:48px}.play-button:hover{background:#ffffff0d;border-color:#ffffff4d}.play-button:disabled{opacity:.5;cursor:not-allowed}.play-button svg{width:22px;height:22px}.play-button.playing{background:#ffffff1a;border-color:#ffffff4d}.no-recordings{text-align:center;color:#fff9;padding:2rem}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
