*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f8f9fb;--surface:#fff;--border:#e2e5ea;--text:#1a1d23;--muted:#6b7280;--primary:#4f46e5;--primary-hover:#4338ca;--danger:#dc2626;--success:#16a34a;--success-bg:#dcfce7;--error-bg:#fef2f2;--error:#dc2626;--radius:8px;--shadow:0 1px 3px #00000014}html{font-size:15px}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,sans-serif;line-height:1.6}.app-header{background:var(--surface);border-bottom:1px solid var(--border);z-index:100;padding:.7rem 1.5rem;position:sticky;top:0}.app-logo{color:var(--text);align-items:center;gap:.5rem;text-decoration:none;display:inline-flex}.app-logo-text{letter-spacing:-.02em;color:var(--text);font-size:1.25rem;font-weight:700}.app-logo-thea{color:var(--primary)}.app-main{max-width:860px;margin:0 auto;padding:1.5rem}.page{animation:.15s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}h1{margin-bottom:1rem;font-size:1.6rem}h2{color:var(--muted);margin:1.25rem 0 .5rem;font-size:1.2rem;font-weight:600}.muted{color:var(--muted);font-size:.9rem}button{cursor:pointer;font:inherit;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);padding:.45rem .9rem;transition:all .15s}button:hover{background:#f0f1f3}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:var(--primary-hover)}.btn-danger{color:var(--danger);border-color:var(--danger);background:0 0}.btn-danger:hover{background:#fef2f2}.btn-sm{padding:.25rem .6rem;font-size:.85rem}.btn-lg{padding:.65rem 1.5rem;font-size:1.1rem}.btn-back{color:var(--primary);background:0 0;border:none;margin-bottom:.75rem;padding:0;font-weight:500}.btn-back:hover{background:0 0;text-decoration:underline}input,select{font:inherit;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);outline:none;padding:.45rem .7rem;transition:border .15s}input:focus,select:focus{border-color:var(--primary)}.inline-form{gap:.5rem;margin-bottom:1rem;display:flex}.inline-form input{flex:1}.card-list{flex-direction:column;gap:.5rem;list-style:none;display:flex}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;box-shadow:var(--shadow);justify-content:space-between;align-items:center;padding:.75rem 1rem;transition:box-shadow .15s,border-color .15s;display:flex}.card:hover{border-color:var(--primary);box-shadow:0 2px 8px #4f46e51f}.card-title{font-weight:600}.badge{color:var(--primary);background:#eef2ff;border-radius:999px;margin-left:.5rem;padding:.1rem .5rem;font-size:.8rem;display:inline-block}.toolbar{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:1rem;display:flex}.toolbar label{color:var(--muted);align-items:center;gap:.3rem;font-size:.9rem;display:flex}.toolbar input[type=range]{width:100px}.lines-editor{flex-direction:column;gap:.35rem;display:flex}.line-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:.4rem;padding:.3rem .5rem;display:flex}.line-num{text-align:right;width:2rem;color:var(--muted);flex-shrink:0;font-size:.85rem}.line-char{text-transform:uppercase;flex-shrink:0;width:120px;font-size:.9rem;font-weight:600}.line-text{flex:1}.line-actions{flex-shrink:0;gap:.2rem;display:flex}.line-actions button{padding:.2rem .45rem;font-size:.85rem}.practice-setup{flex-direction:column;gap:.75rem;max-width:400px;margin-top:1rem;display:flex}.practice-setup select{padding:.5rem}.voice-setup{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:.5rem;padding:.75rem;display:flex}.voice-setup-label{margin-bottom:.15rem;font-size:.9rem;font-weight:600}.voice-row{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.voice-char-name{text-transform:uppercase;font-size:.95rem;font-weight:500}.voice-row select{min-width:100px}.progress-bar{background:var(--border);border-radius:999px;height:6px;margin-bottom:.25rem;overflow:hidden}.progress-fill{background:var(--primary);border-radius:999px;height:100%;transition:width .3s}.script-view{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);max-height:300px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.95rem;overflow-y:auto}.script-line{text-align:start;unicode-bidi:plaintext;border-radius:4px;padding:.3rem .5rem;transition:all .2s}.script-line.active{border-left:3px solid var(--primary);background:#eef2ff;font-weight:500}.script-line.done{opacity:.4}.script-line.user-char strong{color:var(--primary)}.hidden-text{color:var(--muted);letter-spacing:2px;-webkit-user-select:none;user-select:none}.interaction-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1rem;padding:1.25rem}.prompt{margin-bottom:.75rem;font-weight:600}.action-buttons{flex-wrap:wrap;gap:.5rem;margin-top:.5rem;display:flex}.listening{flex-direction:column;align-items:center;gap:.5rem;padding:1rem;display:flex}.pulse{background:var(--primary);border-radius:50%;width:24px;height:24px}.pulse.recording{background:var(--danger);width:32px;height:32px;animation:1s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}.interim{color:var(--muted);font-style:italic}.feedback{border-radius:var(--radius);margin-top:.75rem;padding:.75rem 1rem}.feedback.correct{background:var(--success-bg);color:var(--success)}.feedback.incorrect{background:var(--error-bg);color:var(--error)}.feedback .action-buttons{margin-top:.5rem}.feedback.incorrect .action-buttons button{color:var(--text)}.diff-line{margin:.4rem 0;font-size:1.05rem;line-height:1.8}.word-ok{color:var(--success)}.word-wrong{color:var(--error);text-underline-offset:3px;font-weight:700;-webkit-text-decoration:underline wavy;text-decoration:underline wavy}.diff-spoken{color:var(--muted);margin-top:.25rem;font-size:.9rem}.diff-spoken em{color:var(--text)}.import-stage{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);max-width:600px;padding:1.5rem}.import-heading{margin-bottom:1rem;font-size:1.1rem;font-weight:600}.import-tabs{border-bottom:2px solid var(--border);gap:0;margin-bottom:1rem;display:flex}.import-tab{color:var(--muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;border-radius:0;margin-bottom:-2px;padding:.5rem 1.25rem;font-weight:500}.import-tab:hover{color:var(--text);background:0 0}.import-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.import-panel{flex-direction:column;gap:.75rem;display:flex}.import-panel code{background:#f1f3f5;border-radius:4px;padding:.15rem .4rem;font-size:.85rem}.import-textarea{border:1px solid var(--border);border-radius:var(--radius);resize:vertical;background:var(--bg);outline:none;padding:.75rem;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.9rem;line-height:1.6;transition:border-color .15s}.import-textarea:focus{border-color:var(--primary)}.import-textarea::placeholder{color:#b0b8c4}
