:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}html,body,#root,.homepage-root{width:100vw;min-height:100vh;margin:0;padding:0;background:#fff;box-sizing:border-box;overflow-x:hidden}.nav-bar{display:flex;align-items:center;justify-content:space-between;max-width:1100px;margin:0 auto;padding:0 2rem}.logo{font-size:1.5rem;font-weight:700;color:#fff;letter-spacing:2px}.nav-links{list-style:none;display:flex;gap:2rem;margin:0;padding:0}.nav-links li a{color:#fff;text-decoration:none;font-weight:500;transition:color .2s}.nav-links li a:hover{color:#e53935}.main-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 1rem;text-align:center}.main-content h1{font-size:2.5rem;font-weight:700;color:#1a2233;margin-bottom:2rem}.homepage-header{background:#000;padding:1rem 0;box-shadow:0 2px 8px #00000008}.mode-switch{display:inline-flex;gap:1.2rem;margin:3rem 0 2rem;background:#f5f5f5;border-radius:2rem;box-shadow:0 2px 12px #0000000a;padding:.3rem;align-items:center;min-height:0;max-width:420px;min-width:0}.mode-btn{background:none;border:none;outline:none;font-size:1.05rem;font-weight:600;color:#000;padding:.7rem 2.2rem;border-radius:1.5rem;cursor:pointer;transition:background .2s,color .2s,box-shadow .2s;position:relative;display:flex;align-items:center;gap:.4em;min-height:0;margin:0;box-sizing:border-box}.mode-btn.active{background:#e53935;color:#fff;box-shadow:0 2px 8px #e539351f;border-radius:1.5rem}.mode-btn:not(.active):hover{background:#fce4e4;color:#e53935}.mode-content{width:100%;margin:0 auto;display:flex;flex-direction:column;align-items:center;justify-content:flex-start}.mode-panel{width:100%;background:#fff;border-radius:1.5rem;box-shadow:0 4px 24px #00000012;padding:2.5rem 2rem 2rem;margin-bottom:2rem;text-align:center;transition:box-shadow .2s}.transmit-panel h1,.receive-panel h1{font-size:2rem;font-weight:700;margin-bottom:1rem;color:#e53935}.mode-desc{color:#333;font-size:1.1rem;margin-bottom:0}.transmit-ui,.receive-ui{width:100%;background:#fff;border-radius:1.5rem;box-shadow:0 4px 24px #00000012;padding:2.5rem 2rem 1rem;margin-bottom:0;text-align:center;transition:box-shadow .2s;display:flex;flex-direction:column;align-items:center}.transmit-letter{font-size:3.5rem;font-weight:800;color:#e53935;margin-bottom:1.5rem;letter-spacing:2px}.transmit-morse-display{min-height:2.5rem;font-size:2rem;letter-spacing:.5rem;color:#222;margin-bottom:1.5rem;background:#f5f5f5;border-radius:.75rem;padding:.5rem 1.5rem;display:inline-block}.placeholder{color:#bbb;font-size:1.1rem}.transmit-controls{display:flex;gap:1rem;margin-bottom:1.5rem;justify-content:center}.morse-key-btn{background:#e53935;color:#fff;font-size:1.25rem;font-weight:700;border:none;border-radius:2rem;padding:1rem 2.5rem;cursor:pointer;transition:background .2s,box-shadow .2s;box-shadow:0 2px 8px #e539351a}.morse-key-btn.pressing{background:#b71c1c}.backspace-btn,.submit-btn,.next-btn,.play-btn{background:#fff;color:#e53935;border:2px solid #e53935;border-radius:2rem;font-size:1.1rem;font-weight:600;padding:.75rem 1.5rem;cursor:pointer;transition:background .2s,color .2s}.backspace-btn:disabled,.submit-btn:disabled{opacity:.5;cursor:not-allowed}.submit-btn,.next-btn{margin-left:.5rem}.backspace-btn:hover,.submit-btn:hover,.next-btn:hover,.play-btn:hover{background:#e53935;color:#fff}.transmit-feedback,.receive-feedback{margin-top:1.5rem;font-size:1.2rem;font-weight:600;padding:1rem 1.5rem;border-radius:1rem;display:flex;flex-direction:column;align-items:center}.transmit-feedback.correct,.receive-feedback.correct{background:#e8f5e9;color:#388e3c;border:1.5px solid #388e3c}.transmit-feedback.incorrect,.receive-feedback.incorrect{background:#ffebee;color:#e53935;border:1.5px solid #e53935}.play-btn{margin-bottom:1.5rem}.receive-form{display:flex;gap:1rem;justify-content:center;margin-bottom:1.5rem}.receive-input{font-size:2rem;font-weight:700;width:4rem;text-align:center;border:2px solid #e53935;border-radius:.75rem;padding:.5rem;outline:none;color:#e53935;background:#fff;transition:border .2s}.receive-input:focus{border:2px solid #b71c1c}.keyboard-grid{display:grid;grid-template-columns:repeat(10,2.5rem);gap:.5rem;justify-content:center;margin:1.5rem 0}.keyboard-key{background:#fff;color:#e53935;border:2px solid #e53935;border-radius:.75rem;font-size:1.15rem;font-weight:700;padding:.75rem 0;cursor:pointer;transition:background .2s,color .2s;outline:none}.keyboard-key:hover:not(:disabled),.keyboard-key:focus:not(:disabled){background:#e53935;color:#fff}.keyboard-key:disabled{opacity:.5;cursor:not-allowed}.receive-status{display:flex;justify-content:center;align-items:center;margin-bottom:1.25rem;min-height:2.5rem}.receive-question{font-size:2.5rem;color:#e53935;font-weight:800}.receive-feedback-text{font-size:1.5rem;font-weight:700}.receive-feedback-text.correct{color:#388e3c}.receive-feedback-text.incorrect{color:#e53935}.main-content-home{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 1rem;text-align:center}.main-content-home h1{font-size:2.5rem;font-weight:700;color:#1a2233;margin-bottom:2rem}.get-started-btn{background:#e53935;color:#fff;font-size:1.25rem;padding:.75rem 2.5rem;border:none;border-radius:.5rem;cursor:pointer;font-weight:600;transition:background .2s,color .2s;box-shadow:0 2px 8px #e5393514}.get-started-btn:hover{background:#b71c1c;color:#fff}.core-app-layout{display:flex;flex-direction:row;min-height:calc(100vh - 56px);background:#f9fafb}.main-interface{flex:1;width:0;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;background:#fff;padding:0}.transmit-tip{display:inline-block;background:#fff;color:#333;padding:.18em .5em;border-radius:5px;font-size:.48em;font-weight:400;box-shadow:0 1px 2px #0000000a;margin-top:.2em;margin-bottom:.2em;letter-spacing:.05px}.kbd{display:inline-block;background:#f5f5f5;color:#333;border:1px solid #bbb;border-radius:3px;padding:.05em .3em;font-size:1em;font-family:inherit;font-weight:500;margin:0 .12em;box-shadow:0 1px 1px #0000000a;vertical-align:middle}.morse-key-btn,.backspace-btn,.submit-btn,.next-btn,.play-btn{padding:1.1rem 2.7rem}.settings-icon{margin-left:1.2rem;cursor:pointer;display:flex;align-items:center;color:#e53935;transition:color .2s}.settings-icon:hover,.settings-icon:focus{color:#b71c1c}.settings-modal-overlay{position:fixed;inset:0;background:#0000002e;z-index:1000;display:flex;align-items:center;justify-content:center}.settings-modal{background:#fff;border-radius:1.2rem;box-shadow:0 4px 32px #00000021;padding:2.2rem 2.5rem 1.5rem;min-width:320px;max-width:95vw;position:relative}.settings-modal h2{margin-top:0;margin-bottom:1.2rem;font-size:1.5rem;color:#e53935}.settings-row{margin-bottom:1.5rem;display:flex;flex-direction:column;gap:.7rem}.close-settings-btn{background:#e53935;color:#fff;border:none;border-radius:2rem;font-size:1.1rem;font-weight:600;padding:.7rem 2.2rem;cursor:pointer;transition:background .2s;margin-top:.5rem}.close-settings-btn:hover{background:#b71c1c}.nav-actions{display:flex;align-items:center;gap:1.2rem}.settings-page{max-width:420px;margin:3rem auto 0;background:#fff;border-radius:1.2rem;box-shadow:0 4px 32px #00000021;padding:2.2rem 2.5rem 1.5rem;display:flex;flex-direction:column;align-items:center}.settings-page h2{margin-top:0;margin-bottom:1.2rem;font-size:1.5rem;color:#e53935}.settings-row{margin-bottom:1.5rem;display:flex;flex-direction:column;gap:.7rem;width:100%}.settings-row label{font-size:1.1rem;font-weight:500;color:#333}.settings-row input[type=range]{width:100%;accent-color:#e53935;margin-top:.3rem}.back-btn{background:#e53935;color:#fff;border:none;border-radius:2rem;font-size:1.1rem;font-weight:600;padding:.7rem 2.2rem;cursor:pointer;transition:background .2s;margin-top:.5rem}.back-btn:hover{background:#b71c1c}.switch{position:relative;display:inline-block;width:64px;height:24px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background:#ccc;transition:background .3s;border-radius:24px}.slider:before{position:absolute;content:"";height:24px;width:24px;left:0;top:0;background:#fff;transition:transform .3s;border-radius:50%;box-shadow:0 1px 4px #0000001a}.switch input:checked+.slider{background:#43a047}.switch input:checked+.slider:before{transform:translate(24px)}.switch input:focus+.slider{box-shadow:0 0 1px #43a047}.switch input:active+.slider:before{width:30px}.settings-row label,.settings-row span{color:#111}.modal-backdrop{position:fixed;inset:0;background:#00000059;z-index:1000;display:flex;align-items:center;justify-content:center}.modal{background:#fff;color:#222;border-radius:16px;padding:2.5rem 2rem 2rem;box-shadow:0 8px 32px #0000002e;max-width:400px;width:90vw;text-align:center;z-index:1001}.modal h2{margin-top:0;font-size:1.5rem;font-weight:700}.modal p{margin:1.2em 0;font-size:1.1rem}.modal-close-btn{margin-top:1.5em;padding:.7em 2em;background:#2563eb;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s}.modal-close-btn:hover{background:#1741a6}.main-app-content{position:relative}.help-icon{position:absolute;top:18px;right:18px;z-index:10;background:#fff;border:none;border-radius:50%;box-shadow:0 2px 8px #0000001a;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:box-shadow .2s,background .2s}.help-icon:hover,.help-icon:focus{background:#f0f4ff;box-shadow:0 4px 16px #2563eb1a;outline:none}.help-icon svg{display:block}@media (max-width: 900px){.main-content,.main-content-home{padding:2rem .5rem}.mode-panel,.transmit-ui,.receive-ui{padding:1.5rem 1rem 1rem;margin-bottom:1.2rem}.transmit-letter,.receive-question{font-size:2.2rem}.keyboard-grid{grid-template-columns:repeat(7,2.2rem);gap:.35rem}.mode-switch{gap:1rem;margin:2rem 0 1.2rem;padding:.2rem}.mode-btn{font-size:.98rem;padding:.6rem 1.2rem}.morse-key-btn,.backspace-btn,.submit-btn,.next-btn,.play-btn{padding:.85rem 1.7rem}.mode-content{max-width:100vw;padding:0 .5rem}.receive-ui{max-width:100vw;padding:1.5rem 1rem 1rem;margin-bottom:1.2rem}}@media (max-width: 600px){.main-content,.main-content-home{padding:1rem .2rem}.mode-panel,.transmit-ui,.receive-ui{padding:1rem .2rem .7rem;margin-bottom:.7rem;border-radius:.7rem;box-shadow:0 2px 8px #0000000a}.transmit-letter,.receive-question{font-size:1.5rem;margin-bottom:1rem}.transmit-morse-display{font-size:1.1rem;padding:.3rem .7rem;margin-bottom:1rem}.transmit-controls{flex-direction:column;gap:.5rem;margin-bottom:1rem}.morse-key-btn,.backspace-btn,.submit-btn,.next-btn,.play-btn{font-size:1rem;padding:.7rem 1.2rem;min-width:0;padding:.7rem 1.3rem}.keyboard-grid{grid-template-columns:repeat(5,2rem);gap:.25rem;overflow-x:auto;justify-content:flex-start}.keyboard-key{font-size:.95rem;padding:.5rem 0;min-width:1.7rem}.receive-input{font-size:1.2rem;width:2.5rem;padding:.3rem}.transmit-feedback,.receive-feedback{font-size:1rem;padding:.7rem;margin-top:1rem;border-radius:.6rem}.mode-switch{gap:.5rem;margin:1.2rem 0 .7rem;padding:.12rem}.mode-btn{font-size:.92rem;padding:.5rem .7rem}.morse-key-btn,.backspace-btn,.submit-btn,.next-btn,.play-btn{padding:.7rem 1.3rem}.mode-content{max-width:100vw;padding:0 .2rem}.receive-ui{max-width:100vw;padding:1rem .2rem .7rem;margin-bottom:.7rem;border-radius:.7rem;box-shadow:0 2px 8px #0000000a}}.sbui-modal-close,.sbui-modal__close,.supabase-auth-ui .sbui-btn-container,button[aria-label=Close]{color:#2563eb!important;background:transparent!important;font-size:1.7rem;font-weight:700;border:none;cursor:pointer;z-index:1002}.sbui-modal-close:hover,.sbui-modal__close:hover,.supabase-auth-ui .sbui-btn-container:hover,button[aria-label=Close]:hover{color:#1741a6!important;background:#f0f4ff!important}button[style*="position: absolute"][style*="right: 8px"][style*="top: 8px"]{color:#2563eb!important;background:none!important;border:none!important;font-size:1.7rem!important;font-weight:700;cursor:pointer;z-index:1002}button[style*="position: absolute"][style*="right: 8px"][style*="top: 8px"]:hover,button[style*="position: absolute"][style*="right: 8px"][style*="top: 8px"]:focus{color:#1741a6!important;background:#f0f4ff!important}.sidebar-levels{width:220px;background:#181818;color:#fff;padding:2rem 1rem 2rem 1.5rem;height:100vh;box-shadow:2px 0 12px #0000000a;display:flex;flex-direction:column;align-items:flex-start;overflow-y:auto;position:relative}.sidebar-title{font-size:1.2rem;font-weight:700;margin-bottom:1.5rem;letter-spacing:1px;color:#e53935}.sidebar-level-list{list-style:none;padding:0;margin:0;width:100%}.sidebar-level-item{padding:.75rem 1rem;margin-bottom:.5rem;border-radius:.75rem;cursor:pointer;background:transparent;color:#fff;display:flex;flex-direction:column;border:2px solid transparent;transition:background .2s,border .2s,color .2s;position:relative}.sidebar-level-item.active{background:#fff;color:#e53935;border:2px solid #e53935;font-weight:700}.sidebar-level-item.complete .sidebar-level-label{color:#388e3c}.sidebar-level-item:hover:not(.active){background:#222;color:#e53935}.sidebar-level-label{font-size:1rem;font-weight:600;margin-bottom:.25rem}.sidebar-level-chars{font-size:.95rem;color:#bbb;letter-spacing:1px}.sidebar-level-check{position:absolute;right:1rem;top:1rem;color:#388e3c;font-size:1.2rem;font-weight:700}.sidebar-char{display:flex;align-items:center;margin-right:.5em;font-size:1.1em;color:#bbb;font-weight:600;transition:color .2s}.sidebar-char.char-complete{color:#388e3c;font-weight:700}.total-progress-container{width:100%;margin-bottom:1.5rem;display:flex;flex-direction:column;align-items:flex-start}.total-progress-label{font-size:1rem;font-weight:600;margin-bottom:.5rem;color:#e53935;letter-spacing:.5px}.total-progress-bar-bg{width:100%;height:16px;background:#292929;border-radius:8px;overflow:hidden;margin-bottom:.5rem;box-shadow:0 1px 4px #00000014}.total-progress-bar-fill{height:100%;background:linear-gradient(90deg,#e53935,#ffb300);border-radius:8px 0 0 8px;transition:width .5s cubic-bezier(.4,0,.2,1)}.total-progress-percent{font-size:.95rem;color:#bbb;font-weight:500;margin-left:2px}.letter-progress-bar{display:inline-block;vertical-align:middle;width:22px;height:7px;margin:0 .15em;background:#eee;border-radius:4px;overflow:hidden;position:relative}.letter-progress-half{display:inline-block;height:100%;position:absolute;top:0;transition:width .3s}.letter-progress-half.left{left:0;background:#e53935;border-radius:4px 0 0 4px;z-index:1}.letter-progress-half.right{right:0;background:#ffb300;border-radius:0 4px 4px 0;z-index:1}.letter-progress-dots{display:inline-flex;align-items:center;gap:.18em;font-size:.68em;margin-left:.18em;vertical-align:middle}.mode-indicator{font-weight:700;margin:0 .08em 0 .22em;color:#888;font-size:.92em}.dot{display:inline-block;width:.65em;height:.65em;border-radius:50%;background:#eee;color:#bbb;text-align:center;line-height:.65em;font-size:1em;margin:0 .04em;transition:background .2s,color .2s}.dot.filled{background:#43a047;color:#fff}.letter-progress-checks{display:inline-flex;align-items:center;gap:.08em;font-size:.72em;margin-left:.12em;vertical-align:middle}.check{font-size:1em;margin:0 .01em;vertical-align:middle;opacity:.85}.letter-progress-boxes{display:inline-flex;align-items:center;gap:.08em;font-size:.72em;margin-left:.12em;vertical-align:middle}.letter-label{font-size:1.25em;font-weight:800;color:#222;letter-spacing:1px;margin-right:.18em;vertical-align:middle;transition:color .2s,background .2s}.sidebar-level-item:not(.active) .letter-label,.sidebar-char .letter-label{color:#fff;background:#222;border-radius:.22em;padding:.04em .22em;font-weight:800}.progress-box{display:inline-flex;align-items:center;justify-content:center;width:1.1em;height:1.1em;border-radius:.18em;background:#eee;color:#bbb;font-size:.92em;font-weight:500;margin:0 .03em;border:1.5px solid #ddd;box-sizing:border-box;transition:background .2s,color .2s;letter-spacing:0}.progress-box.filled{background:#43a047;color:#fff;border-color:#43a047;font-weight:700}.letter-score-bar-wrapper{display:flex;align-items:center;min-width:54px;position:relative;margin:0 .08em}.letter-score-bar-bg{width:48px;height:7px;background:#e6f4ea;border-radius:4px;overflow:hidden;position:relative;margin-right:2px;margin-left:2px;display:inline-block}.letter-score-bar-bg.mode-transmit{background:#e6f4ea}.letter-score-bar-bg.mode-receive{background:#e3f0fa}.letter-score-bar-fill{height:100%;background:linear-gradient(90deg,#43a047,#4fc3f7);border-radius:4px 0 0 4px;transition:width .3s cubic-bezier(.4,0,.2,1);position:absolute;left:0;top:0;z-index:1}.letter-score-bar-threshold{position:absolute;top:0;bottom:0;width:1px;background:#000;opacity:.7;z-index:2}.letter-score-check{display:none}.letter-score-bars-vertical{display:flex;flex-direction:column;gap:2px;margin-left:.4em;margin-right:.1em;align-items:flex-start}.letter-score-bar-fill.blue{background:#4fc3f7}.letter-score-bar-fill.green{background:#43a047}@media (max-width: 600px){.sidebar-levels{display:none}.mobile-progress-nav{display:flex;position:fixed;bottom:0;left:0;width:100vw;background:#181818;color:#fff;z-index:1000;align-items:center;justify-content:space-between;padding:.5rem;box-shadow:0 -2px 12px #0000001f;min-height:64px}.mobile-progress-left{flex:1 1 50%;display:flex;align-items:center;justify-content:flex-start;padding-left:.7rem}.mobile-progress-right{flex:1 1 50%;display:flex;align-items:center;justify-content:flex-end;padding-right:.7rem;gap:.5rem}.mobile-level-switcher{background:#292929;color:#e53935;border:none;border-radius:8px;padding:.5rem 1rem;font-size:1rem;font-weight:600;cursor:pointer;min-width:80px;min-height:44px;outline:none;box-shadow:0 1px 4px #00000014}.mobile-level-chars-inline{display:flex;gap:.3rem;margin-right:.5rem}.mobile-level-char-inline{display:inline-block;min-width:28px;min-height:32px;font-size:1.1em;color:#bbb;font-weight:600;background:none;border:none;border-radius:6px;text-align:center;line-height:32px;padding:0 .15em;transition:color .2s,background .2s}.mobile-level-char-inline.char-complete{color:#388e3c;font-weight:700}.mobile-level-modal-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;z-index:2000;display:flex;align-items:flex-end;justify-content:center}.mobile-level-modal{background:#222;width:100vw;max-height:80vh;border-radius:18px 18px 0 0;box-shadow:0 -2px 16px #0000002e;padding:1.2rem .5rem 2rem;overflow-y:auto;position:relative;display:flex;flex-direction:column;align-items:stretch}.mobile-level-modal-header{display:flex;align-items:center;justify-content:space-between;font-size:1.2rem;font-weight:700;color:#fff;margin-bottom:1rem;padding:0 .5rem}.mobile-level-modal-close{background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;margin-left:1rem;line-height:1}.mobile-level-modal-list{list-style:none;padding:0;margin:0;width:100%}.mobile-level-modal-item{padding:.7rem 1rem;margin-bottom:.5rem;border-radius:.75rem;cursor:pointer;background:transparent;color:#fff;display:flex;flex-direction:column;border:2px solid transparent;transition:background .2s,border .2s,color .2s;position:relative}.mobile-level-modal-item.active{background:#fff;color:#e53935;border:2px solid #e53935;font-weight:700}.mobile-level-modal-label{font-size:1rem;font-weight:600;margin-bottom:.25rem}.mobile-level-modal-chars{font-size:.95rem;color:#bbb;letter-spacing:1px}.mobile-level-modal-char{display:inline-block;margin-right:.5em;font-size:1.1em;color:#bbb;font-weight:600;transition:color .2s}.mobile-level-modal-char.char-complete{color:#388e3c;font-weight:700}.mobile-progress-bar{display:flex;flex-direction:column;align-items:flex-start;min-width:60px;font-size:.95rem}.mobile-progress-label{color:#e53935;font-weight:600;margin-bottom:2px;font-size:.95rem}.mobile-progress-bar-bg{width:60px;height:8px;background:#292929;border-radius:4px;overflow:hidden;margin-bottom:.5rem;box-shadow:0 1px 4px #00000014}.mobile-progress-bar-fill{height:100%;background:linear-gradient(90deg,#e53935,#ffb300);border-radius:4px 0 0 4px;transition:width .5s cubic-bezier(.4,0,.2,1)}}
