:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color:#1f2937;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;min-width:320px;min-height:100vh}.btn{display:inline-block;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;text-align:center;text-decoration:none;border:none;border-radius:.5rem;cursor:pointer;transition:all .2s;font-family:inherit}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #007aff66}.btn-outline{background:transparent;border:2px solid #007aff;color:#007aff}.btn-outline:hover:not(:disabled){background:#007aff;color:#fff}.btn-large{padding:1rem 2rem;font-size:1.125rem}.btn-small{padding:.5rem 1rem;font-size:.875rem}.btn-block{width:100%;display:block}.logo-container{display:flex;align-items:center;gap:.75rem}.logo-svg{flex-shrink:0}.logo-text{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#007aff,#5856d6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing{min-height:100vh}.landing-nav{position:fixed;top:0;left:0;right:0;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid #e5e7eb;z-index:100;padding:1rem 0}.nav-content{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.logo-link{display:flex;align-items:center;text-decoration:none;color:inherit}.logo{display:flex;align-items:center;gap:1rem;font-size:1.5rem;font-weight:700;color:#007aff}.logo-morse{font-family:monospace;font-size:1.2rem;color:#666}.logo-text{background:linear-gradient(135deg,#007aff,#5856d6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav-links{display:flex;gap:1rem}.hero{padding:8rem 2rem 4rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-align:center;min-height:80vh;display:flex;align-items:center;justify-content:center}.hero-content{max-width:800px;margin:0 auto}.hero-title{font-size:3.5rem;font-weight:800;margin-bottom:1.5rem;line-height:1.2}.highlight{background:linear-gradient(90deg,#fbbf24,#f59e0b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.25rem;opacity:.9;margin-bottom:2rem;line-height:1.6}.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.morse-demo{margin-top:4rem;padding:2rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:1rem;border:1px solid rgba(255,255,255,.2)}.morse-pattern{font-size:2.5rem;font-family:monospace;letter-spacing:.5rem;margin-bottom:1rem}.dot{color:#fbbf24}.dash{color:#f59e0b}.space{width:2rem;display:inline-block}.morse-translation{font-size:1.5rem;font-weight:600;letter-spacing:.5rem;margin:0}.features{padding:6rem 2rem;background:#f9fafb}.container{max-width:1200px;margin:0 auto}.section-title{text-align:center;font-size:2.5rem;font-weight:700;margin-bottom:3rem;color:#1f2937}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.feature-card{background:#fff;padding:2rem;border-radius:1rem;box-shadow:0 4px 6px #0000000d;transition:transform .2s,box-shadow .2s}.feature-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001a}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{font-size:1.5rem;font-weight:600;margin-bottom:1rem;color:#1f2937}.feature-card p{color:#6b7280;line-height:1.6}.how-it-works{padding:6rem 2rem;background:#fff}.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:3rem;margin-top:3rem}.step{text-align:center}.step-number{display:inline-flex;align-items:center;justify-content:center;width:4rem;height:4rem;background:linear-gradient(135deg,#007aff,#5856d6);color:#fff;font-size:2rem;font-weight:700;border-radius:50%;margin-bottom:1.5rem}.step h3{font-size:1.5rem;font-weight:600;margin-bottom:1rem;color:#1f2937}.step p{color:#6b7280;line-height:1.6}.cta{padding:6rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-align:center}.cta h2{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.cta p{font-size:1.25rem;opacity:.9;margin-bottom:2rem}.footer{background:#1f2937;color:#fff;padding:3rem 2rem 1rem}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:2rem}.footer-section h4{font-size:1.125rem;font-weight:600;margin-bottom:1rem}.footer-section p{color:#9ca3af;line-height:1.6}.footer-section ul{list-style:none;padding:0;margin:0}.footer-section li{margin-bottom:.5rem}.footer-section a{color:#9ca3af;text-decoration:none;transition:color .2s}.footer-section a:hover{color:#fff}.footer-bottom{border-top:1px solid #374151;padding-top:2rem;text-align:center;color:#9ca3af}@media(max-width:768px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1rem}.morse-pattern{font-size:1.5rem}.section-title{font-size:2rem}.features-grid,.steps{grid-template-columns:1fr}.nav-content{flex-direction:column;gap:1rem}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.auth-container{background:#fff;border-radius:1rem;padding:3rem;width:100%;max-width:450px;box-shadow:0 20px 60px #0000004d}.auth-header{text-align:center;margin-bottom:2rem}.auth-logo{display:inline-flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;text-decoration:none}.auth-logo .logo-morse{font-family:monospace;font-size:1rem;color:#666}.auth-logo .logo-text{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#007aff,#5856d6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-header h1{font-size:2rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.auth-header p{color:#6b7280;font-size:1rem}.error-message{background:#fee;color:#c33;padding:1rem;border-radius:.5rem;margin-bottom:1.5rem;border:1px solid #fcc;font-size:.875rem}.auth-form,.form-group{margin-bottom:1.5rem}.form-group input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus{outline:none;border-color:#007aff;box-shadow:0 0 0 3px #007aff1a}.auth-divider{position:relative;text-align:center;margin:1.5rem 0}.auth-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#e5e7eb}.auth-divider span{position:relative;background:#fff;padding:0 1rem;color:#9ca3af;font-size:.875rem}.btn-google{display:flex;align-items:center;justify-content:center;gap:.75rem;background:#fff;border:1px solid #d1d5db;color:#374151;font-weight:500}.btn-google:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.auth-footer{text-align:center;margin-top:2rem;padding-top:2rem;border-top:1px solid #e5e7eb}.auth-footer p{color:#6b7280;font-size:.875rem}.auth-footer a{color:#007aff;text-decoration:none;font-weight:500}.auth-footer a:hover{text-decoration:underline}@media(max-width:640px){.auth-container{padding:2rem}.auth-header h1{font-size:1.5rem}}.dashboard{min-height:100vh;background:#f9fafb}.dashboard-loading{display:flex;justify-content:center;align-items:center;height:100vh}.dashboard-header{background:#fff;border-bottom:1px solid #e5e7eb;padding:1rem 0;position:sticky;top:0;z-index:100}.dashboard-header-content{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.dashboard-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none}.dashboard-logo .logo-morse{font-family:monospace;font-size:1rem;color:#666}.dashboard-logo .logo-text{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#007aff,#5856d6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dashboard-nav{display:flex;align-items:center;gap:1rem}.dashboard-main{padding:2rem}.dashboard-container{max-width:1200px;margin:0 auto}.dashboard-welcome{margin-bottom:3rem}.dashboard-welcome h1{font-size:2.5rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.dashboard-welcome p{font-size:1.125rem;color:#6b7280;margin-bottom:1.5rem}.quick-actions{display:flex;gap:1rem;margin-top:1.5rem}.dashboard-section{margin-bottom:3rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{font-size:1.5rem;font-weight:600;color:#1f2937}.section-controls{display:flex;gap:1rem;align-items:center}.search-input{padding:.5rem 1rem;border:1px solid #d1d5db;border-radius:.5rem;background:#fff;color:#374151;font-size:.875rem;transition:all .2s;min-width:250px}.search-input::placeholder{color:#9ca3af}.search-input:hover{border-color:#9ca3af}.search-input:focus{outline:none;border-color:#007aff;box-shadow:0 0 0 3px #007aff1a}.filter-select{padding:.5rem 1rem;border:1px solid #d1d5db;border-radius:.5rem;background:#fff;color:#374151;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.filter-select:hover{border-color:#9ca3af}.filter-select:focus{outline:none;border-color:#007aff;box-shadow:0 0 0 3px #007aff1a}.packages-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.package-card{background:#fff;border-radius:1rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a;transition:transform .2s,box-shadow .2s;position:relative;display:flex;flex-direction:column;min-height:280px}.package-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.package-icon{font-size:3rem;margin-bottom:1rem}.package-type-badge{position:absolute;top:1rem;right:1rem;padding:.25rem .75rem;background:#e5e7eb;color:#374151;font-size:.75rem;font-weight:600;text-transform:uppercase;border-radius:.5rem}.package-card h3{font-size:1.25rem;font-weight:600;color:#1f2937;margin-bottom:.5rem}.package-card p{color:#6b7280;font-size:.875rem;line-height:1.5;margin-bottom:1rem;flex:1}.package-progress{margin-bottom:1rem;margin-top:auto}.progress-bar{width:100%;height:.5rem;background:#e5e7eb;border-radius:.25rem;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,#007aff,#5856d6);transition:width .3s}.progress-text{font-size:.75rem;color:#6b7280;margin:0}.progress-text.no-progress{font-style:italic;color:#9ca3af}.package-actions{display:flex;gap:.5rem;margin-top:auto}.empty-state{text-align:center;padding:4rem 2rem}.empty-state h3{font-size:1.5rem;font-weight:600;color:#1f2937;margin-bottom:.5rem}.empty-state p{color:#6b7280;margin-bottom:1.5rem}.pagination-controls{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:2rem;padding-top:2rem;border-top:1px solid #e5e7eb}.pagination-info{color:#6b7280;font-size:.875rem;font-weight:500}.pagination-controls button:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.dashboard-header-content{flex-direction:column;gap:1rem}.dashboard-nav{flex-direction:column;gap:.5rem}.dashboard-welcome h1{font-size:2rem}.packages-grid{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start;gap:1rem}.section-controls{flex-direction:column;width:100%}.search-input{width:100%;min-width:auto}.filter-select{width:100%}.pagination-controls{flex-direction:column;gap:.75rem}}.package-editor{background:#fff;border-radius:12px;padding:32px;box-shadow:0 2px 8px #0000000d}.editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:16px;border-bottom:1px solid var(--color-gray-200)}.editor-header h2{font-size:24px;margin:0}.editor-form{display:flex;flex-direction:column;gap:32px}.form-section{display:flex;flex-direction:column;gap:20px}.form-section h3{font-size:18px;margin:0 0 12px;color:var(--color-gray-900)}.section-header{display:flex;justify-content:space-between;align-items:center}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.form-check{display:flex;align-items:center;gap:8px}.form-check input[type=checkbox]{width:20px;height:20px;cursor:pointer}.form-check label{cursor:pointer;-webkit-user-select:none;user-select:none;margin:0}.form-check .help-text{display:block;margin-top:4px;font-size:12px;color:var(--color-gray-600);font-style:italic}.preserved-fields-info{margin-top:24px;padding:16px;background:#fff3cd;border:1px solid #ffc107;border-radius:8px}.preserved-fields-info h4{font-size:14px;margin:0 0 12px;color:#856404}.metadata-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:12px}.metadata-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#fff;border-radius:4px;border:1px solid #e0e0e0}.metadata-label{font-size:13px;font-weight:600;color:var(--color-gray-700)}.metadata-value{font-size:13px;color:var(--color-gray-900);font-weight:500}.info-text{display:block;font-size:12px;color:#856404;font-style:italic}.levels-list{display:flex;flex-direction:column;gap:16px}.level-card{border:1px solid var(--color-gray-200);border-radius:8px;padding:20px;background-color:var(--color-gray-100)}.level-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:8px}.level-header h4{font-size:16px;margin:0}.level-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.level-form{display:flex;flex-direction:column;gap:12px}.level-form .form-group{margin-bottom:0}.level-form input[type=number]{max-width:150px}.form-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:24px;border-top:1px solid var(--color-gray-200)}.success-message{background:linear-gradient(135deg,#11998e,#38ef7d);border:2px solid #10b981;color:#fff;padding:16px 20px;border-radius:8px;margin-bottom:20px;font-weight:600;font-size:15px;box-shadow:0 4px 12px #10b98133;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.package-stats{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:24px;color:#fff}.package-stats h3{font-size:16px;margin:0 0 16px;font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}.stat-item{display:flex;flex-direction:column;gap:4px;padding:12px;background:#ffffff26;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.stat-label{font-size:12px;opacity:.9;font-weight:500}.stat-value{font-size:24px;font-weight:700}.levels-section{position:relative}.levels-container{display:grid;grid-template-columns:250px 1fr;gap:20px;align-items:start}.level-navigator{position:sticky;top:20px;background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:8px;padding:16px;max-height:calc(100vh - 100px);overflow-y:auto;display:flex;flex-direction:column;gap:16px}.nav-actions{display:flex;flex-direction:column;gap:8px;padding-bottom:16px;border-bottom:2px solid var(--color-gray-300)}.nav-success-badge{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff;padding:12px;border-radius:6px;font-size:13px;font-weight:600;text-align:center;animation:slideIn .3s ease-out;box-shadow:0 2px 8px #10b98133}.nav-error-badge{background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff;padding:12px;border-radius:6px;font-size:13px;font-weight:600;text-align:center;animation:slideIn .3s ease-out;box-shadow:0 2px 8px #ef444433}.btn-block{width:100%;justify-content:center;font-weight:600}.level-navigator h4{font-size:14px;font-weight:600;margin:0;color:var(--color-gray-700)}.level-nav-list{display:flex;flex-direction:column;gap:6px}.level-nav-item{display:flex;align-items:center;gap:10px;padding:10px;background:#fff;border:1px solid var(--color-gray-200);border-radius:6px;cursor:pointer;transition:all .2s;text-align:left;font-size:13px}.level-nav-item:hover{background:var(--color-gray-100);border-color:var(--color-primary)}.level-nav-item.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.level-nav-number{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--color-gray-200);border-radius:50%;font-weight:600;font-size:12px;flex-shrink:0}.level-nav-item.active .level-nav-number{background:#ffffff4d}.level-nav-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.level-nav-message{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.level-nav-words{font-size:11px;opacity:.7}.level-nav-item.active .level-nav-words{opacity:.9}.level-card.selected{border-color:var(--color-primary);box-shadow:0 0 0 3px #4a90e21a}.words-section{margin-top:16px;padding:16px;background:#fff;border-radius:6px;border:1px solid var(--color-gray-300)}.words-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.section-header-left{display:flex;align-items:center;gap:8px}.section-header-actions{display:flex;gap:8px}.words-section h5{font-size:14px;font-weight:600;margin:0;color:var(--color-gray-700)}.btn-ghost{background:transparent;border:none;color:var(--color-gray-600);padding:4px 8px;cursor:pointer;border-radius:4px;transition:background .2s}.btn-ghost:hover{background:var(--color-gray-100)}.words-list{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto;margin-bottom:12px}.word-item{display:flex;flex-direction:column;gap:8px;padding:12px;background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:4px}.word-item-main{display:flex;align-items:center;gap:8px}.word-item-main input{flex:1;padding:6px 10px;border:1px solid var(--color-gray-300);border-radius:4px;font-size:14px}.word-item-main input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #4a90e21a}.word-item-main button{padding:4px 12px;font-size:12px;background:var(--color-danger, #dc3545);color:#fff;border:none;border-radius:4px;cursor:pointer;white-space:nowrap}.word-item-main button:hover{background:#c82333}.word-item-options{display:flex;flex-wrap:wrap;gap:16px;padding-left:4px}.word-item-options .form-check{display:flex;align-items:center;gap:6px}.word-item-options .form-check input[type=checkbox]{width:16px;height:16px;cursor:pointer}.word-item-options .form-check label{font-size:13px;color:var(--color-gray-700);cursor:pointer;-webkit-user-select:none;user-select:none;margin:0}.words-section .btn-secondary{width:100%;justify-content:center;font-size:14px;padding:8px}@media(max-width:1024px){.levels-container{grid-template-columns:1fr}.level-navigator{position:static;max-height:200px}.level-nav-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}@media(max-width:768px){.package-editor{padding:16px}.editor-header{flex-direction:column;align-items:flex-start;gap:12px}.form-row{grid-template-columns:1fr}.section-header-actions{flex-direction:column;width:100%}.section-header-actions .btn{width:100%}.word-item-options{flex-direction:column;align-items:flex-start}}.package-editor-page{min-height:100vh;background:var(--background-color, #f5f5f5);padding:2rem}.editor-container{max-width:1200px;margin:0 auto;padding:2rem;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.error-message{color:#dc3545;padding:1rem;background:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;margin-bottom:1rem}@media(prefers-color-scheme:dark){.package-editor-page{background:#1a1a1a}.editor-container{background:#2a2a2a;color:#fff}}.traditional-pad{position:fixed;bottom:0;left:0;right:0;height:150px;background-color:#646464cc;display:flex;justify-content:center;align-items:center;cursor:pointer;user-select:none;-webkit-user-select:none;touch-action:none}.traditional-pad.pressed{background-color:#969696e6}.split-container{position:fixed;bottom:0;left:0;right:0;height:150px;display:flex;flex-direction:row}.split-pad{flex:1;display:flex;justify-content:center;align-items:center;cursor:pointer;user-select:none;-webkit-user-select:none;touch-action:none}.dot-pad{background-color:#5078c8cc}.dot-pad.pressed{background-color:#82aafae6}.dash-pad{background-color:#c87850cc}.dash-pad.pressed{background-color:#faaa82e6}.divider{width:2px;background-color:#fff}.pad-content{display:flex;flex-direction:column;align-items:center;pointer-events:none}.pad-label{font-size:32px;font-weight:700;color:#fff}.pad-hint{font-size:16px;color:#ddd;margin-top:8px}.split-label{font-size:64px;font-weight:700;color:#fff}.split-hint{font-size:18px;color:#ddd;margin-top:8px}.traditional-pad *,.split-pad *{user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.game-screen{position:fixed;inset:0;background:linear-gradient(180deg,#1a1a2e,#16213e);overflow:hidden}.game-loading,.game-error{display:flex;justify-content:center;align-items:center;height:100vh;color:#fff;font-size:20px}.game-header{display:flex;justify-content:space-between;align-items:center;padding:20px;background-color:#0000004d;gap:12px}.menu-button{background:#fff3;border:none;color:#fff;font-size:28px;width:50px;height:50px;border-radius:25px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.menu-button:hover{background:#ffffff4d}.game-info{display:flex;gap:20px;font-size:20px;color:#fff;font-weight:700;flex-shrink:1;min-width:0;flex:1}.shortcuts-button{background:#fff3;border:none;color:#fff;font-size:24px;width:50px;height:50px;border-radius:25px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s ease}.shortcuts-button:hover{background:#ffffff4d;transform:scale(1.05)}.score{color:gold}.level{color:#4ecca3}.game-area{position:relative;height:calc(100vh - 230px);overflow:hidden}.word-entity{position:absolute;display:flex;flex-direction:row;align-items:center;transition:opacity .3s;transform-origin:center}.word-entity.hit{opacity:0;transform:scale(1.5)}.word-entity.missed{opacity:.5}.word-container{display:flex;flex-direction:row;gap:2px}.letter-hint{font-size:10px;color:#fff;font-family:monospace;margin-top:2px;line-height:1}.letter-hint.clicked{color:gold;font-weight:700;animation:hintPulse .3s ease-out}@keyframes hintPulse{0%{transform:scale(1);opacity:.7}50%{transform:scale(1.2);opacity:1}to{transform:scale(1);opacity:1}}.letter-tile.clicked-hint{background-color:#ffd70026;border:2px solid rgba(255,215,0,.5)}.word-hint{position:absolute;top:100%;left:50%;transform:translate(-50%);font-size:14px;color:#4ecca3;font-family:monospace;letter-spacing:2px;white-space:nowrap;margin-top:4px}.pattern-display{position:fixed;bottom:170px;left:50%;transform:translate(-50%);background-color:#000c;padding:16px 24px;border-radius:12px;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:100}.pattern-text{font-size:32px;color:#fff;font-family:monospace;letter-spacing:8px;min-width:100px;text-align:center}.timing-hint{font-size:12px;color:#4ecca3;margin-top:4px;font-family:monospace}.clear-button{background-color:#ff3b30cc;border:none;color:#fff;padding:6px 16px;border-radius:16px;cursor:pointer;font-size:14px;font-weight:700}.clear-button:hover{background-color:#ff3b30}.pause-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:200}.pause-indicator{background-color:#1a1a2e;border-radius:20px;padding:40px;text-align:center;border:3px solid #007aff}.pause-icon{font-size:80px;display:block;margin-bottom:20px}.pause-indicator h2{color:#fff;font-size:32px;margin-bottom:30px;letter-spacing:4px}.resume-button{background-color:#007aff;border:none;color:#fff;padding:16px 40px;border-radius:12px;font-size:24px;font-weight:700;cursor:pointer}.resume-button:hover{background-color:#0056b3}.menu-overlay{position:fixed;inset:0;background-color:#00000080;z-index:90}.menu-panel{position:fixed;top:0;right:0;bottom:0;width:280px;background-color:#2d2d44;padding:60px 20px 20px;z-index:100;box-shadow:-2px 0 8px #00000080}.menu-panel h2{color:#fff;font-size:24px;font-weight:700;margin-bottom:30px;text-align:center}.menu-item{width:100%;background-color:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:16px 20px;border-radius:12px;margin-bottom:16px;display:flex;align-items:center;gap:12px;cursor:pointer;font-size:16px;font-weight:600}.menu-item:hover{background-color:#fff3}.menu-item span{font-size:24px;width:32px;text-align:center}.menu-item-danger{background-color:#ff3b3033;border-color:#ff3b3066}.menu-item-danger:hover{background-color:#ff3b304d}.close-menu{width:100%;background:none;border:none;color:#999;padding:12px;margin-top:20px;cursor:pointer;font-size:16px;font-weight:600}.close-menu:hover{color:#fff}.game-over-overlay{position:fixed;inset:0;background-color:#000c;display:flex;justify-content:center;align-items:center;z-index:300;padding-bottom:150px}.game-over-box{background-color:#fff;border-radius:16px;padding:40px;text-align:center;min-width:300px;max-width:400px;margin:0 20px}.game-over-text{color:red;font-size:32px;font-weight:700;margin-bottom:20px}.level-complete-text{color:#14b8a6;font-size:32px;font-weight:700;margin-bottom:10px}.celebration{font-size:48px;margin-bottom:20px}.final-score{font-size:24px;font-weight:700;color:#333;margin-bottom:12px}.stats{font-size:18px;color:#666;margin-bottom:24px}.try-again-button,.back-button{width:100%;padding:16px;margin-bottom:12px;border:none;border-radius:8px;font-size:18px;font-weight:700;cursor:pointer}.try-again-button{background-color:#007aff;color:#fff}.try-again-button:hover{background-color:#0056b3}.back-button{background-color:#f0f0f0;color:#333}.back-button:hover{background-color:#e0e0e0}.level-selection-panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:600px;max-height:80vh;background-color:#2d2d44;border-radius:16px;padding:24px;z-index:200;box-shadow:0 8px 32px #00000080;display:flex;flex-direction:column;overflow:hidden}.level-selection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.1)}.level-selection-header h2{color:#fff;font-size:28px;font-weight:700;margin:0}.level-selection-package-info{display:flex;align-items:center;gap:16px;margin-bottom:20px;padding:16px;background-color:#ffffff0d;border-radius:12px}.level-selection-package-info .package-icon{font-size:40px}.level-selection-package-info h3{color:#fff;font-size:20px;font-weight:600;margin:0 0 4px}.level-selection-package-info p{color:#fff9;font-size:14px;margin:0}.level-selection-list{flex:1;overflow-y:auto;padding-right:8px}.level-selection-list::-webkit-scrollbar{width:8px}.level-selection-list::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.level-selection-list::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.level-selection-list::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.level-selection-item{width:100%;background-color:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px;margin-bottom:12px;display:flex;align-items:center;gap:16px;cursor:pointer;transition:all .2s ease}.level-selection-item:hover{background-color:#ffffff1a;border-color:#fff3;transform:translate(4px)}.level-selection-item.current{background-color:#22c55e33;border-color:#22c55e}.level-selection-number{width:50px;height:50px;border-radius:25px;background-color:#3b82f633;border:2px solid #3b82f6;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:20px;font-weight:700;color:#3b82f6}.level-selection-item.current .level-selection-number{background-color:#22c55e4d;border-color:#22c55e;color:#22c55e}.level-selection-info{flex:1;min-width:0}.level-selection-name-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}.level-selection-name{color:#fff;font-size:18px;font-weight:600}.level-selection-badge{background-color:#22c55e33;color:#22c55e;padding:4px 8px;border-radius:6px;font-size:12px;font-weight:600;border:1px solid #22c55e}.level-selection-stats{display:flex;flex-wrap:wrap;gap:8px}.level-selection-stat{color:#fff9;font-size:13px;background-color:#ffffff0d;padding:4px 8px;border-radius:4px}.level-selection-arrow{width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:#fff6;font-size:20px;flex-shrink:0}.shortcuts-panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:500px;background-color:#2d2d44;border-radius:16px;padding:0;z-index:200;box-shadow:0 8px 32px #00000080;display:flex;flex-direction:column;max-height:80vh;position:relative}.shortcuts-close-button{position:absolute;top:16px;right:16px;background:none;border:none;color:#ffffffb3;font-size:28px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:50%;transition:all .2s ease;z-index:10}.shortcuts-close-button:hover{background-color:#ffffff1a;color:#fff;transform:scale(1.1)}.shortcuts-panel-header{display:flex;justify-content:center;align-items:center;padding:24px 24px 16px;border-bottom:1px solid rgba(255,255,255,.1)}.shortcuts-panel-header h2{color:#fff;font-size:24px;font-weight:700;margin:0}.shortcuts-content{padding:24px;overflow-y:auto;flex:1}.shortcuts-section{margin-bottom:24px}.shortcuts-section h3{color:#ffffffe6;font-size:18px;font-weight:600;margin-bottom:16px}.shortcuts-list{display:flex;flex-direction:column;gap:12px}.shortcut-item{display:flex;align-items:center;gap:16px;padding:12px;background-color:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.keyboard-key{background-color:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:6px;padding:6px 12px;min-width:40px;text-align:center;font-size:16px;font-weight:600;color:#fff;font-family:monospace;box-shadow:0 2px 4px #0003;flex-shrink:0}.shortcut-description{color:#ffffffe6;font-size:16px;font-weight:500;flex:1}.shortcuts-footer{margin-top:24px;padding-top:16px;border-top:1px solid rgba(255,255,255,.1)}.shortcuts-note{color:#fff9;font-size:14px;text-align:center;margin:0}.practice-mode{min-height:100vh;background:linear-gradient(180deg,#1a1a2e,#16213e);color:#fff;padding-bottom:170px;overflow-x:hidden;max-width:100vw}.practice-header{display:flex;justify-content:space-between;align-items:center;padding:20px;background-color:#0000004d;gap:12px}.practice-header h1{font-size:24px;font-weight:700;margin:0;flex:1;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.back-button,.mode-button{background-color:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:16px;font-weight:600;white-space:nowrap;flex-shrink:0!important;flex-grow:0!important;flex-basis:auto!important;width:auto!important;max-width:fit-content}.back-button:hover,.mode-button:hover{background-color:#fff3}.practice-content{padding:20px;max-width:800px;margin:0 auto}.practice-content.with-tap-pad{padding-bottom:0}.input-section{background-color:#ffffff0d;border-radius:12px;padding:20px;margin-bottom:20px}.input-section label{display:block;font-size:16px;font-weight:700;margin-bottom:12px;color:#4ecca3}.input-section input{width:100%;background-color:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;font-size:18px;padding:12px;border-radius:8px;box-sizing:border-box}.input-section input::placeholder{color:#666}.help-text{color:#888;font-size:12px;margin-top:8px;font-style:italic}.mode-section{margin-bottom:20px}.mode-section label{display:block;font-size:16px;font-weight:700;margin-bottom:12px;color:#4ecca3}.mode-toggle{display:flex;gap:12px}.mode-toggle-button{flex:1;background-color:#ffffff0d;border:2px solid transparent;color:#888;padding:16px;border-radius:8px;cursor:pointer;font-size:16px;font-weight:700}.mode-toggle-button.active{background-color:#4ecca333;border-color:#4ecca3;color:#4ecca3}.mode-toggle-button:hover{background-color:#ffffff1a}.listen-section{background-color:#ffffff0d;border-radius:12px;padding:20px}.display-box{background-color:#ffffff1a;padding:20px;border-radius:8px;margin-bottom:16px}.display-text{font-size:24px;text-align:center;font-family:monospace;color:#fff}.playback-button{width:100%;background-color:#4ecca3;border:none;color:#fff;padding:16px;border-radius:8px;font-size:18px;font-weight:700;cursor:pointer;margin-bottom:8px}.playback-button:hover{background-color:#3db894}.playback-button:disabled{background-color:#333;opacity:.5;cursor:not-allowed}.tap-section{background-color:#ffffff0d;border-radius:12px;padding:20px}.practice-word-container{display:flex;flex-direction:column;align-items:center;margin-bottom:20px}.word-container{display:flex;flex-direction:row;gap:2px;justify-content:center;flex-wrap:wrap}.letter-tile{width:80px;height:80px;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#fffffff2;border-radius:8px;margin:0 2px;position:relative;box-shadow:0 2px 4px #00000040;transition:background-color .2s ease}.letter-tile.small{width:60px;height:60px}.letter-tile.tiny{width:40px;height:40px}.letter-tile.current{background-color:#007aff4d;border:3px solid #007AFF}.letter-tile.completed{background-color:#14b8a64d}.letter-tile.completing,.letter-tile.completing.completed{animation:letterComplete .3s ease-out!important}@keyframes letterComplete{0%{transform:scale(1)!important;background-color:#fffffff2!important}50%{transform:scale(1.3)!important;background-color:#14b8a6e6!important}to{transform:scale(1)!important;background-color:#14b8a64d!important}}.letter-text{font-size:40px;font-weight:700;color:#007aff;text-align:center;line-height:1}.letter-tile.small .letter-text{font-size:30px}.letter-tile.tiny .letter-text{font-size:20px}.letter-tile.completed .letter-text{color:#14b8a6}.letter-hint{font-size:10px;color:#fff;font-family:monospace;margin-top:2px;line-height:1;background-color:#00000080;padding:2px 4px;border-radius:4px}.letter-tile.small .letter-hint{font-size:8px}.letter-tile.tiny .letter-hint{font-size:6px}.letter-checkmark{position:absolute;top:2px;right:2px;font-size:16px;color:#14b8a6;font-weight:700;line-height:1}.letter-tile.small .letter-checkmark{font-size:12px;top:1px;right:1px}.letter-tile.tiny .letter-checkmark{font-size:10px;top:1px;right:1px}.practice-word-container .progress-text{margin-top:12px;font-size:16px;color:#888}.current-char-display{text-align:center;margin-bottom:20px}.char-and-progress{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:12px}.current-char-text{font-size:56px;font-weight:700;color:#fff}.progress-text{font-size:18px;color:#888}.expected-morse{font-size:28px;color:#4ecca3;font-family:monospace;letter-spacing:8px}.pattern-display{background-color:#0000004d;padding:16px;border-radius:8px;margin-bottom:16px;text-align:center}.pattern-text{font-size:36px;color:#fff;font-family:monospace;letter-spacing:8px;min-height:48px;display:flex;align-items:center;justify-content:center}.pattern-hint{font-size:18px;color:gold;margin-top:8px;font-weight:700}.timing-info{font-size:12px;color:#4ecca3;margin-top:8px;font-family:monospace}.action-buttons{display:flex;gap:12px;margin-bottom:16px}.action-buttons button{flex:1;padding:12px;border:none;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;color:#fff}.clear-button{background-color:#e94560}.clear-button:hover{background-color:#d13550}.check-button{background-color:#4ecca3}.check-button:hover{background-color:#3db894}.check-button:disabled{background-color:#333;opacity:.5;cursor:not-allowed}.reset-button{background-color:#ff9500}.reset-button:hover{background-color:#e68500}.stats-row{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px;padding:12px;background-color:#0003;border-radius:8px}.accuracy-text{font-size:18px;font-weight:700;color:#4ecca3}.recent-results{display:flex;gap:8px}.result-badge{padding:6px 12px;border-radius:6px;font-size:14px;font-weight:700;border-left:3px solid}.result-badge.success{background-color:#4ccca333;border-left-color:#4ecca3;color:#4ecca3}.result-badge.failure{background-color:#e9456033;border-left-color:#e94560;color:#e94560}.results-detail{margin-top:20px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1)}.results-detail h3{font-size:16px;margin-bottom:12px;color:#4ecca3}.result-item{display:flex;flex-direction:column;gap:4px;padding:12px;border-radius:8px;margin-bottom:8px;border-left:4px solid;font-size:14px}.result-item.success{background-color:#4ccca31a;border-left-color:#4ecca3}.result-item.failure{background-color:#e945601a;border-left-color:#e94560}.result-char{font-size:24px;font-weight:700;color:#fff}.result-morse{font-family:monospace;color:#ddd;font-size:16px;letter-spacing:4px}.result-status{font-size:24px;position:absolute;right:20px;top:50%;transform:translateY(-50%)}@media(max-width:768px){.practice-content{padding:12px}.current-char-text{font-size:42px}.pattern-text{font-size:28px}.stats-row{flex-direction:column;align-items:flex-start}.pattern-display.empty-pattern{display:none}}.settings{min-height:100vh;background:#f9fafb}.settings-loading{display:flex;justify-content:center;align-items:center;height:100vh}.settings-header{background:#fff;border-bottom:1px solid #e5e7eb;padding:1rem 0;position:sticky;top:0;z-index:100}.settings-header-content{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.settings-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none}.settings-logo .logo-morse{font-family:monospace;font-size:1rem;color:#666}.settings-logo .logo-text{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#007aff,#5856d6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.settings-nav{display:flex;align-items:center;gap:1rem}.user-email{color:#6b7280;font-size:.875rem}.settings-main{padding:2rem}.settings-container{max-width:800px;margin:0 auto}.settings-header-section{margin-bottom:2rem}.settings-header-section h1{font-size:2.5rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.settings-header-section p{font-size:1.125rem;color:#6b7280}.settings-message{padding:1rem;border-radius:.5rem;margin-bottom:1.5rem;font-size:.875rem}.settings-error{background:#fee;color:#c33;border:1px solid #fcc}.settings-success{background:#efe;color:#3c3;border:1px solid #cfc}.settings-section{background:#fff;border-radius:1rem;padding:2rem;margin-bottom:2rem;box-shadow:0 1px 3px #0000001a}.settings-section h2{font-size:1.5rem;font-weight:600;color:#1f2937;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e5e7eb}.settings-subsection{margin-bottom:2rem}.settings-subsection:last-child{margin-bottom:0}.settings-subsection h3{font-size:1.125rem;font-weight:600;color:#374151;margin-bottom:1rem}.form-group{margin-bottom:1.5rem}.form-group:last-child{margin-bottom:0}.form-group label{display:block;font-weight:500;color:#374151;margin-bottom:.5rem;font-size:.875rem}.form-group input[type=range],.form-group input[type=text],.form-group input[type=number],.form-group select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;transition:border-color .2s,box-shadow .2s;background:#fff;color:#374151}.form-group input.form-error{border-color:#dc3545}.form-group input.form-error:focus{border-color:#dc3545;box-shadow:0 0 0 3px #dc35451a}.form-group input[type=checkbox].toggle-switch{width:3rem!important;min-width:3rem!important;max-width:3rem!important;padding:0!important;border:none!important;border-radius:9999px!important;background:#d1d5db!important}.form-group input[type=range]{padding:.5rem 0;cursor:pointer}.form-group input[type=number]{max-width:200px}.form-group input:focus,.form-group select:focus{outline:none;border-color:#007aff;box-shadow:0 0 0 3px #007aff1a}.form-group input:disabled{background:#f3f4f6;cursor:not-allowed}.form-help{margin-top:.5rem;font-size:.75rem;color:#6b7280}.range-labels{display:flex;justify-content:space-between;margin-top:.25rem;font-size:.75rem;color:#6b7280}.toggle-group{display:flex;align-items:flex-start;gap:1.5rem;width:100%;overflow:visible}.toggle-group label{flex:1 1 0%;min-width:0;margin-bottom:0;cursor:pointer;padding-right:1rem;flex-shrink:1}.toggle-group label span:first-child{display:block;font-weight:500;color:#374151;margin-bottom:.25rem}.form-help-text{display:block;font-size:.75rem;color:#6b7280;font-weight:400}.toggle-switch{width:3rem!important;min-width:3rem!important;max-width:3rem!important;flex-shrink:0!important;flex-grow:0!important;height:1.5rem;appearance:none;background:#d1d5db;border-radius:9999px;position:relative;cursor:pointer;transition:background .2s;padding:0;margin:0;box-sizing:border-box}.toggle-switch:checked{background:#007aff!important}.form-group input[type=checkbox].toggle-switch:checked{background:#007aff!important}.toggle-switch:before{content:"";position:absolute;width:1.25rem;height:1.25rem;border-radius:50%;background:#fff;top:.125rem;left:.125rem;transition:transform .2s;box-shadow:0 1px 2px #0003}.toggle-switch:checked:before{transform:translate(1.5rem)}.settings-actions{margin-top:2rem;display:flex;justify-content:flex-end;padding-top:2rem;border-top:1px solid #e5e7eb}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border-radius:.5rem;font-size:.875rem;font-weight:500;text-decoration:none;border:none;cursor:pointer;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#007aff,#5856d6);color:#fff}.btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px);box-shadow:0 4px 12px #007aff4d}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#6b7280;color:#fff}.btn-secondary:hover:not(:disabled){background:#4b5563}.btn-outline{background:#fff;color:#374151;border:1px solid #d1d5db}.btn-outline:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.btn-small{padding:.5rem 1rem;font-size:.8125rem}.btn-large{padding:1rem 2rem;font-size:1rem}@media(max-width:768px){.settings-header-content{flex-direction:column;gap:1rem}.settings-nav{flex-direction:column;gap:.5rem;width:100%}.settings-nav>*{width:100%}.settings-header-section h1{font-size:2rem}.settings-section{padding:1.5rem}.toggle-group{flex-direction:column;gap:.5rem}.toggle-switch{align-self:flex-end}.form-group input[type=number]{max-width:100%}.settings-actions{justify-content:stretch}.settings-actions .btn{width:100%}}.chat-list{min-height:100vh;background-color:#1a1a2e;color:#fff;display:flex;flex-direction:column}.chat-list-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid rgba(255,255,255,.1)}.chat-list-header h1{margin:0;font-size:24px;font-weight:700}.chat-list-back-button{background-color:#007aff;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;transition:background-color .2s ease}.chat-list-back-button:hover{background-color:#0056b3}.chat-list-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.1);padding:0 20px}.chat-list-tab{background:transparent;border:none;color:#666;padding:16px 24px;cursor:pointer;font-size:14px;font-weight:600;border-bottom:2px solid transparent;transition:all .2s ease;position:relative}.chat-list-tab:hover{color:#fff}.chat-list-tab.active{color:#007aff;border-bottom-color:#007aff}.chat-list-tab-badge{background-color:#007aff;color:#fff;border-radius:10px;padding:2px 6px;font-size:11px;margin-left:6px}.chat-list-content{flex:1;overflow-y:auto;padding:20px}.chat-list-empty{text-align:center;padding:60px 20px;color:#666}.chat-list-loading{text-align:center;padding:40px;color:#666}.chat-list-item{display:flex;align-items:center;padding:16px;background-color:#ffffff0d;border-radius:12px;margin-bottom:12px;cursor:pointer;transition:background-color .2s ease}.chat-list-item:hover{background-color:#ffffff1a}.chat-list-item-avatar{width:48px;height:48px;border-radius:50%;background-color:#007aff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;margin-right:12px;flex-shrink:0;position:relative;overflow:visible}.chat-list-avatar-image{width:48px;height:48px;border-radius:50%;object-fit:cover}.chat-list-online-indicator{position:absolute;bottom:0;right:0;width:12px;height:12px;border-radius:50%;background-color:#34c759;border:2px solid #1a1a2e}.chat-list-item-info{flex:1;min-width:0}.chat-list-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.chat-list-item-username{font-weight:600;font-size:16px;color:#fff}.chat-list-item-time{font-size:12px;color:#666}.chat-list-item-status{font-size:12px}.chat-list-item-preview{font-size:13px;color:#aaa;font-family:Courier New,Courier,monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-list-item-morse{font-family:Courier New,Courier,monospace}.chat-list-item-bio{font-size:13px;color:#aaa;margin-bottom:4px}.chat-list-item-stats{font-size:12px;color:#666;margin-bottom:8px}.chat-list-item-actions{display:flex;gap:8px;margin-top:8px}.chat-list-action-button{background-color:#ffffff1a;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:13px;transition:background-color .2s ease}.chat-list-action-button:hover{background-color:#fff3}.chat-list-action-button.primary{background-color:#007aff}.chat-list-action-button.primary:hover{background-color:#0056b3}.chat-list-action-button.accept{background-color:#34c759}.chat-list-action-button.accept:hover{background-color:#28a745}.chat-list-action-button.decline{background-color:#ff3b30}.chat-list-action-button.decline:hover{background-color:#d32f2f}.chat-list-item-unread{background-color:#007aff;color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.chat-list-search{margin-bottom:20px}.chat-list-search-input{width:100%;padding:12px;background-color:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;font-size:14px}.chat-list-search-input::placeholder{color:#666}.chat-list-search-input:focus{outline:none;border-color:#007aff}.chat-list-privacy-banner{background-color:#007aff26;border-bottom:1px solid rgba(0,122,255,.3);padding:12px 20px}.chat-list-privacy-banner-content{display:flex;align-items:center;justify-content:space-between}.chat-list-privacy-banner-text{color:#007aff;font-size:13px;flex:1}.chat-list-privacy-banner-close{background:transparent;border:none;color:#007aff;font-size:18px;font-weight:700;cursor:pointer;padding:4px 8px;margin-left:8px;transition:opacity .2s ease}.chat-list-privacy-banner-close:hover{opacity:.7}.chat-list-privacy-controls{background-color:#ffffff0d;border-bottom:1px solid rgba(255,255,255,.1);padding:16px 20px}.chat-list-privacy-control-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.chat-list-privacy-control-row:last-child{margin-bottom:0}.chat-list-privacy-control-label{color:#fff;font-size:14px;font-weight:500;flex:1}.chat-list-privacy-toggle{width:44px;height:24px;cursor:pointer}.chat-list-privacy-control-buttons{display:flex;gap:8px}.chat-list-privacy-control-button{background-color:#ffffff1a;color:#aaa;border:1px solid transparent;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;transition:all .2s ease}.chat-list-privacy-control-button:hover{background-color:#ffffff26}.chat-list-privacy-control-button.active{background-color:#007aff;color:#fff;border-color:#007aff}.chat-list-friend-actions{display:flex;flex-direction:column;align-items:center;justify-content:center;margin-left:16px}.chat-list-friend-time{font-size:12px;color:#666;margin-bottom:8px;text-align:center}.chat-list-action-button.remove{background-color:#ff3b3033;color:#ff3b30}.chat-list-action-button.remove:hover{background-color:#ff3b304d}.morse-composer{background-color:#16161e;border-top:1px solid rgba(255,255,255,.1)}.morse-composer-status{padding:16px 16px 12px;background-color:#0000004d;border-bottom:1px solid rgba(255,255,255,.1)}.morse-composer-status-row{display:flex;align-items:center;margin-bottom:8px}.morse-composer-status-label{font-size:12px;color:#666;margin-right:8px}.morse-composer-pattern{font-size:18px;font-family:Courier New,Courier,monospace;font-weight:700;color:#4ecca3;letter-spacing:2px}.morse-composer-sentence-preview{font-size:16px;color:#fff;font-weight:600;flex:1}.morse-composer-word-count{font-size:14px;color:#4ecca3;font-weight:700}.morse-composer-char-count{font-size:14px;color:#aaa}.morse-composer-mode-indicator{margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.morse-composer-mode-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.morse-composer-mode-badge.mode-traditional{background-color:#4ecca333;color:#4ecca3;border:1px solid rgba(78,204,163,.3)}.morse-composer-mode-badge.mode-iambic{background-color:#007aff33;color:#007aff;border:1px solid rgba(0,122,255,.3)}.morse-composer-mode-badge.mode-split{background-color:#ffc10733;color:#ffc107;border:1px solid rgba(255,193,7,.3)}.morse-composer-controls{padding:12px 16px}.morse-composer-controls-row{display:flex;gap:8px;margin-bottom:12px}.morse-composer-control-button{flex:1;background-color:#ffffff1a;padding:12px 8px;border-radius:8px;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;transition:background-color .2s ease}.morse-composer-control-button:hover{background-color:#ffffff26}.morse-composer-control-button:active{background-color:#fff3}.morse-composer-clear-button{background-color:#ff3b3033}.morse-composer-clear-button:hover{background-color:#ff3b304d}.morse-composer-control-button-text{font-size:16px;color:#fff;font-weight:700;margin-bottom:2px}.morse-composer-control-button-subtext{font-size:10px;color:#666}.morse-composer-send-button{width:100%;background-color:#007aff;padding:14px;border-radius:12px;border:none;cursor:pointer;font-size:16px;color:#fff;font-weight:700;transition:background-color .2s ease}.morse-composer-send-button:hover:not(:disabled){background-color:#0056b3}.morse-composer-send-button:disabled,.morse-composer-send-button-disabled{background-color:#333;cursor:not-allowed;opacity:.5}.morse-composer-help{padding:16px}.morse-composer-help-text{font-size:11px;color:#666;text-align:center;line-height:16px;margin:0}.morse-composer-help-text kbd{background-color:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:3px;padding:2px 6px;font-family:monospace;font-size:10px;margin:0 2px;display:inline-block}.morse-learning-composer{display:flex;flex-direction:column;gap:16px;padding:16px;background:#ffffff0d;border-radius:12px;border:1px solid rgba(255,255,255,.1)}.morse-learning-input-section{display:flex;flex-direction:column;gap:8px}.morse-learning-label{font-size:14px;font-weight:600;color:#ffffffe6;margin-bottom:4px}.morse-learning-text-input{width:100%;padding:12px;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:#0000004d;color:#fff;font-size:16px;font-family:inherit;resize:vertical;min-height:80px}.morse-learning-text-input:focus{outline:none;border-color:#fff6;background:#0006}.morse-learning-character-counter{font-size:12px;color:#fff9;text-align:right}.morse-learning-morse-section{display:flex;flex-direction:column;gap:8px}.morse-learning-morse-display{padding:16px;border-radius:8px;font-family:Courier New,monospace;font-size:20px;font-weight:700;letter-spacing:4px;text-align:center;min-height:60px;display:flex;align-items:center;justify-content:center}.morse-learning-morse-display.expected{background:#6496ff33;border:2px solid rgba(100,150,255,.4);color:#96c8ff;line-height:1.6}.morse-learning-morse-char{display:inline-block;transition:color .2s ease}.morse-learning-morse-char-completed{color:#96ff96;font-weight:600;text-shadow:0 0 8px rgba(150,255,150,.5)}.morse-learning-morse-char-current{color:#ff9696;font-weight:700;text-shadow:0 0 8px rgba(255,150,150,.5)}.morse-learning-morse-char-upcoming{color:#96c8ff99}.morse-learning-char-space{display:inline-block;width:.5em}.morse-learning-word-separator{display:inline-block;color:#96c8ffcc;margin:0 .5em;font-weight:600}.morse-learning-cursor{display:inline-block;margin-left:2px;color:#ffc864;font-weight:700;font-family:Courier New,monospace}.morse-learning-cursor-blink{display:inline-block;animation:blink 1s infinite;color:#fff;margin-left:2px;font-weight:700}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.morse-learning-error-message{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#ff646433;border:2px solid rgba(255,100,100,.5);border-radius:8px;animation:shake .3s ease-in-out}.morse-learning-error-icon{font-size:24px;flex-shrink:0}.morse-learning-error-text{font-size:14px;color:#ffc8c8;font-weight:600;line-height:1.4}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.morse-learning-status-section{display:flex;flex-direction:column;gap:12px;padding:12px;background:#0003;border-radius:8px}.morse-learning-status-row{display:flex;align-items:center;gap:12px}.morse-learning-status-label{font-size:13px;font-weight:600;color:#ffffffb3;min-width:120px}.morse-learning-pattern,.morse-learning-tapped,.morse-learning-progress,.morse-learning-sentence{font-size:14px;color:#ffffffe6;font-family:Courier New,monospace}.morse-learning-pattern{color:#ffc864;font-weight:700}.morse-learning-tapped{color:#96ff96;font-family:Courier New,monospace;letter-spacing:2px}.morse-learning-tapped-empty{color:#96c8ff80;font-style:italic}.morse-learning-tapped-char{display:inline-block;color:#96ff96}.morse-learning-progress{color:#c8c8ff;font-weight:600}.morse-learning-sentence{color:#fffffff2}.morse-learning-controls{display:flex;flex-direction:column;gap:12px}.morse-learning-controls-row{display:flex;gap:12px}.morse-learning-control-button{flex:1;padding:12px 16px;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:#ffffff1a;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:4px}.morse-learning-control-button:hover:not(:disabled){background:#fff3;border-color:#ffffff4d}.morse-learning-control-button:active:not(:disabled){background:#ffffff26}.morse-learning-control-button-text{font-size:18px}.morse-learning-control-button-subtext{font-size:11px;color:#ffffffb3}.morse-learning-clear-button{background:#ff646433;border-color:#ff646466}.morse-learning-clear-button:hover:not(:disabled){background:#ff64644d;border-color:#ff646480}.morse-learning-send-button{width:100%;padding:16px;border:none;border-radius:8px;background:linear-gradient(135deg,#64c8ffcc,#6496ffcc);color:#fff;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #6496ff4d}.morse-learning-send-button:hover:not(:disabled){background:linear-gradient(135deg,#78dcffe6,#78aaffe6);box-shadow:0 6px 16px #6496ff66;transform:translateY(-1px)}.morse-learning-send-button:active:not(:disabled){transform:translateY(0)}.morse-learning-send-button-disabled{background:#6464644d;color:#ffffff80;cursor:not-allowed;box-shadow:none}.morse-learning-send-button-disabled:hover{background:#6464644d;transform:none;box-shadow:none}.morse-learning-help{padding:12px;background:#0003;border-radius:8px;border-left:3px solid rgba(100,150,255,.5)}.morse-learning-help-text{font-size:12px;color:#ffffffb3;line-height:1.6;margin:0}.morse-learning-help-text kbd{background:#ffffff1a;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;font-size:11px}.tappable-morse-code{display:flex;flex-wrap:wrap;align-items:center;margin-bottom:12px;width:100%}.tappable-morse-word-wrapper{display:inline-flex;align-items:center;margin-right:4px;margin-bottom:4px;flex-shrink:1;max-width:100%}.tappable-morse-word{background:transparent;border:none;padding:2px 4px;cursor:pointer;font-family:Courier New,Courier,monospace;font-size:inherit;color:inherit;flex-shrink:1;transition:background-color .2s ease;border-radius:2px}.tappable-morse-word:hover{background-color:#ffffff1a}.tappable-morse-word.playing{background-color:#ffff004d;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.tappable-morse-word.long-word{font-size:14px}.tappable-morse-word.medium-word{font-size:16px}.tappable-morse-separator{opacity:.5;margin:0 4px;-webkit-user-select:none;user-select:none}.chat-room{display:flex;flex-direction:column;height:100vh;background-color:#1a1a2e;color:#fff}.chat-room-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.1);background-color:#16161e}.chat-room-back-button{background:transparent;border:none;color:#007aff;font-size:16px;cursor:pointer;padding:8px;min-width:60px;transition:opacity .2s ease}.chat-room-back-button:hover{opacity:.7}.chat-room-header-info{flex:1;display:flex;flex-direction:column;align-items:center}.chat-room-header-username{font-size:16px;font-weight:700;color:#fff}.chat-room-header-status{font-size:11px;color:#666;margin-top:2px}.chat-room-privacy-message{background-color:#007aff1a;border-bottom:1px solid rgba(0,122,255,.2);padding:12px 20px;text-align:center;color:#007aff;font-size:12px;line-height:18px}.chat-room-messages{flex:1;overflow-y:auto;padding:16px 16px 20px}.chat-room-empty-state{display:flex;flex-direction:column;align-items:center;padding:60px 20px}.chat-room-empty-icon{font-size:48px;margin-bottom:16px}.chat-room-empty-text{font-size:16px;color:#aaa;font-weight:600;margin-bottom:8px}.chat-room-empty-subtext{font-size:13px;color:#666;text-align:center;padding:0 40px}.chat-room-message-container{margin-bottom:12px;display:flex}.chat-room-message-container.my-message{justify-content:flex-end}.chat-room-message-container.their-message{justify-content:flex-start}.chat-room-message-bubble{max-width:80%;padding:12px;border-radius:16px}.chat-room-message-bubble.my-bubble{background-color:#007aff;border-bottom-right-radius:4px}.chat-room-message-bubble.their-bubble{background-color:#ffffff1a;border-bottom-left-radius:4px}.chat-room-morse-code-large{font-size:20px;font-family:Courier New,Courier,monospace;font-weight:700;margin-bottom:12px;letter-spacing:2px}.chat-room-morse-code-large.my-morse{color:#fffffff2}.chat-room-morse-code-large.their-morse{color:#ffffffe6}.chat-room-hidden-text-container{margin-bottom:12px;opacity:.3}.chat-room-hidden-text{font-size:15px;letter-spacing:1px}.chat-room-revealed-text{font-size:15px;margin-bottom:12px;padding:4px 8px;background-color:#0003;border-radius:6px;border-left:3px solid rgba(255,255,255,.5)}.chat-room-my-text,.chat-room-their-text{color:#fff}.chat-room-action-buttons{display:flex;gap:8px;margin-bottom:8px}.chat-room-action-button{padding:8px 12px;border-radius:8px;min-width:40px;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;font-size:16px;transition:background-color .2s ease}.chat-room-action-button.my-action{background-color:#fff3}.chat-room-action-button.their-action{background-color:#ffffff1a}.chat-room-action-button:hover{background-color:#ffffff40}.chat-room-action-button.active{background-color:#007aff80}.chat-room-message-footer{display:flex;align-items:center;gap:8px;margin-bottom:8px}.chat-room-timestamp{font-size:11px}.chat-room-my-timestamp{color:#ffffffb3}.chat-room-their-timestamp{color:#666}.chat-room-wpm{font-size:10px;font-weight:600}.chat-room-my-wpm{color:#ffffffb3}.chat-room-their-wpm{color:#666}.chat-room-input-container{border-top:1px solid rgba(255,255,255,.1);background-color:#16161e;padding-bottom:10px}.chat-room-input-mode-toggle{display:flex;align-items:center;padding:12px 16px;gap:8px}.chat-room-mode-button{flex:1;padding:8px 16px;background-color:#ffffff0d;border-radius:8px;border:none;color:#666;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.chat-room-mode-button:hover{background-color:#ffffff1a}.chat-room-mode-button.active{background-color:#007aff;color:#fff}.chat-room-auto-play-toggle{display:flex;align-items:center;gap:8px;margin-left:auto;font-size:13px;color:#aaa;cursor:pointer;-webkit-user-select:none;user-select:none}.chat-room-auto-play-toggle input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#007aff}.chat-room-auto-play-toggle:hover{color:#fff}.chat-room-text-input-row{display:flex;align-items:flex-end;padding:12px 16px;gap:8px}.chat-room-text-input{flex:1;background-color:#ffffff1a;border-radius:20px;padding:10px 16px;color:#fff;font-size:15px;border:none;resize:vertical;max-height:100px;font-family:inherit}.chat-room-text-input::placeholder{color:#666}.chat-room-text-input:focus{outline:none;background-color:#ffffff26}.chat-room-send-button{background-color:#007aff;border-radius:20px;padding:10px 20px;border:none;color:#fff;font-size:15px;font-weight:700;cursor:pointer;transition:background-color .2s ease}.chat-room-send-button:hover:not(:disabled){background-color:#0056b3}.chat-room-send-button.disabled{background-color:#333;cursor:not-allowed;opacity:.5}.chat-room-character-counter{font-size:11px;color:#666;text-align:right;padding:4px 16px 8px}#root{min-height:100vh}
