.keyboard{display:flex;flex-direction:column;gap:6px;padding:12px;background:#e8edf5;border-radius:var(--radius)}.keyboard-row{display:flex;flex-wrap:wrap;gap:5px;justify-content:center}.key-btn{min-width:44px;height:48px;padding:0 8px;border-radius:8px;background:#fff;font-size:1.1rem;font-weight:600;color:var(--text);box-shadow:0 2px #c0c8d8;transition:all .08s;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none}.key-btn:active{transform:translateY(2px);box-shadow:none}.key-btn:hover{background:#f0f4ff}.key-wide{padding:0 14px;font-size:.9rem}.key-space{flex:4;font-size:.9rem;background:#fff;box-shadow:0 2px #c0c8d8}.key-backspace{background:#fde8e8;color:#c0392b}.key-clear{background:#fef3cd;color:#7c5c00}.keyboard-main{display:flex;gap:6px;align-items:stretch}.keyboard-qwertz{flex:1;display:flex;flex-direction:column;gap:6px}.key-enter{width:93px;flex-shrink:0;border-radius:8px;background:var(--primary);color:#fff;box-shadow:0 2px 0 var(--primary-dark);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-size:1.6rem;line-height:1;transition:all .08s;-webkit-user-select:none;user-select:none}.key-enter-label{font-size:.7rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.key-enter:disabled{opacity:.4;cursor:not-allowed}.key-enter:not(:disabled):hover{background:var(--primary-dark)}.key-enter:not(:disabled):active{transform:translateY(2px);box-shadow:none}.keyboard-actions{margin-top:4px;justify-content:stretch}.keyboard-actions .key-clear,.keyboard-actions .key-backspace{flex:1}.word-composer{display:flex;flex-direction:column;gap:24px;position:relative}.composer-top{display:flex;flex-direction:column;gap:12px}.text-display{background:#fff;border:2px solid var(--primary);border-radius:var(--radius);padding:16px 20px;font-size:2rem;font-weight:700;min-height:72px;display:flex;align-items:center;letter-spacing:4px;box-shadow:var(--shadow);gap:8px}.read-btn{margin-left:auto;font-size:1.6rem;padding:4px 8px;border-radius:8px;transition:opacity .15s,transform .1s;flex-shrink:0}.read-btn:disabled{opacity:.25;cursor:not-allowed}.read-btn:not(:disabled):hover{transform:scale(1.15)}.read-btn:not(:disabled):active{transform:scale(.95)}.placeholder{color:var(--text-muted);font-weight:400;font-size:1.2rem;letter-spacing:0}.cursor{display:inline-block;width:3px;height:1.8rem;background:var(--primary);margin-left:4px;animation:blink 1s step-end infinite}@keyframes blink{50%{opacity:0}}.word-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:12px}.word-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:10px 8px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:transform .12s,box-shadow .12s;-webkit-user-select:none;user-select:none;position:relative}.word-remove-btn{position:absolute;top:-8px;right:-8px;width:22px;height:22px;border-radius:50%;background:#e74c3c;color:#fff;font-size:1rem;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;line-height:1}.word-card:hover .word-remove-btn{opacity:1}.word-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.word-card:active{transform:scale(.96)}.word-img{width:80px;height:80px;border-radius:8px;object-fit:cover}.word-label{font-size:.9rem;font-weight:600;text-align:center;color:var(--text)}.generating-overlay{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--primary);color:#fff;padding:10px 24px;border-radius:20px;font-size:.9rem;box-shadow:var(--shadow)}.sentence-composer{display:flex;flex-direction:column;gap:28px}.sentence-area{display:flex;flex-direction:column;gap:12px}.sentence-label{font-size:.85rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.sentence-drop-zone{min-height:130px;background:#fff;border:2px dashed var(--primary);border-radius:var(--radius);padding:12px;display:flex;flex-wrap:wrap;gap:10px;align-items:flex-start;transition:background .15s}.sentence-drop-zone.drag-active{background:#eef4ff;border-color:var(--accent)}.drop-hint{color:var(--text-muted);font-size:.95rem;align-self:center;padding:0 8px}.sentence-word{background:var(--bg);border-radius:10px;padding:8px;display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;cursor:grab;border:2px solid transparent;transition:border-color .12s,transform .12s;width:90px}.sentence-word:hover{border-color:var(--primary)}.sentence-word.insert-before{border-left-color:var(--accent)}.remove-btn{position:absolute;top:-8px;right:-8px;width:22px;height:22px;border-radius:50%;background:#e74c3c;color:#fff;font-size:1rem;line-height:22px;text-align:center;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}.sentence-word:hover .remove-btn{opacity:1}.sw-img{width:60px;height:60px;border-radius:8px;object-fit:cover}.sw-label{font-size:.8rem;font-weight:600;text-align:center}.sentence-controls{display:flex;gap:10px}.ctrl-btn{padding:10px 20px;border-radius:8px;font-size:1rem;font-weight:600;transition:opacity .15s,transform .1s}.ctrl-btn:disabled{opacity:.4;cursor:not-allowed}.ctrl-btn:not(:disabled):active{transform:scale(.97)}.ctrl-read{background:var(--primary);color:#fff}.ctrl-read:not(:disabled):hover{background:var(--primary-dark)}.ctrl-save{background:#e8f5e9;color:#2e7d32}.ctrl-save:not(:disabled):hover{background:#c8e6c9}.ctrl-clear{background:#fde8e8;color:#c0392b}.saved-sentences-section{display:flex;flex-direction:column}.saved-sentences-list{display:flex;flex-direction:column;gap:8px}.saved-sentence-row{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:10px 12px;display:flex;align-items:center;gap:10px;cursor:grab;border:2px solid transparent;transition:border-color .12s,transform .12s}.saved-sentence-row:active{cursor:grabbing}.saved-sentence-row.drag-over{border-color:var(--accent);transform:scale(1.01)}.saved-sentence-row.touch-dragging{opacity:.45;transform:scale(.97);border-color:var(--primary);background:#eef4ff}.saved-sentence-row.touch-insert-before,.saved-sentence-row.touch-insert-after{position:relative}.saved-sentence-row.touch-insert-before:before,.saved-sentence-row.touch-insert-after:after{content:"";position:absolute;left:8px;right:8px;height:3px;background:var(--accent);border-radius:2px;pointer-events:none}.saved-sentence-row.touch-insert-before:before{top:-5px}.saved-sentence-row.touch-insert-after:after{bottom:-5px}.saved-read-btn{padding:8px 12px;font-size:1rem;flex-shrink:0}.saved-sentence-words{display:flex;flex-wrap:wrap;gap:6px;flex:1}.saved-word-chip{display:flex;align-items:center;gap:4px;background:var(--bg);border-radius:6px;padding:4px 8px;font-size:.85rem;font-weight:600}.chip-img{width:28px;height:28px;border-radius:4px;object-fit:cover}.saved-delete-btn{width:28px;height:28px;border-radius:50%;background:#fde8e8;color:#c0392b;font-size:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.saved-delete-btn:hover{background:#f5c6cb}.sentence-text{background:#eef4ff;border-radius:8px;padding:10px 14px;font-size:1.1rem;font-weight:600;color:var(--primary-dark);letter-spacing:.5px}.section-title{font-size:1rem;font-weight:600;color:var(--text-muted);margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}.empty-hint{color:var(--text-muted);font-size:.95rem;padding:20px 0}.palette-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px}.palette-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:10px 8px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:grab;transition:transform .12s,box-shadow .12s;-webkit-user-select:none;user-select:none;border:2px solid transparent}.palette-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026;border-color:var(--primary)}.palette-card:active{cursor:grabbing}.pw-img{width:70px;height:70px;border-radius:8px;object-fit:cover}.pw-label{font-size:.85rem;font-weight:600;text-align:center;color:var(--text)}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:var(--primary);color:#fff;padding:12px 16px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow);position:sticky;top:0;z-index:10}.app-title{font-size:1.4rem;font-weight:700;letter-spacing:.5px}.app-nav{display:flex;gap:8px;margin-left:auto}.nav-btn{padding:8px 16px;border-radius:20px;font-size:.95rem;font-weight:500;color:#fffc;transition:all .15s}.nav-btn:hover{background:#ffffff26;color:#fff}.nav-btn.active{background:#fff;color:var(--primary)}.app-main{flex:1;padding:16px;max-width:900px;width:100%;margin:0 auto}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #4f86c6;--primary-dark: #3a6fa8;--accent: #f0a500;--bg: #f5f7fb;--surface: #ffffff;--text: #1a1a2e;--text-muted: #6b7280;--radius: 12px;--shadow: 0 2px 8px rgba(0,0,0,.1)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;-webkit-tap-highlight-color:transparent}button{cursor:pointer;border:none;background:none;font-family:inherit}#root{min-height:100vh;display:flex;flex-direction:column}
